Node.js | 从前端到全栈的必经之路
前言
对于前端开发的朋友们,是否有这样的烦恼或需求:
想要开发一个心仪的项目但没有后端朋友的合作,而只能使用
mock
?与后端合作开发中总感觉约束,不能很好的交流所想,从而拖慢进度?
不甘心自己只能和他人合作开发,想要自己独立实现效果?
想提高自己的地位,丰富自己的知识面,从而能够在团队中独当一面?
习惯了个人开发,自由惯了,不想随波逐流服从安排?
等等
当你有这些问题时,就该是时候问问自己是不是想要发展为全栈,如果是,那么学习Node.js
就该是你进击全栈的必经之路!
一、什么是 Node
Node.js
是一个javascript
运行环境,它让javascript
可以开发后端程序,实现几乎其他后端语言实现的所有功能!
这意味着我们只需要掌握javaScript
一门语言就能够进行全栈开发!
学习
Node
我们可以非常平滑的过渡到全栈开发,并且如果你之前学习过Vue
,React
等前端框架或者Webpack
这些,那么其实你就已经接触过 Node 了,因为它们都是建立于 Node 基础上的,如:Vue、React 的脚手架:Vue-cli,create-react-app,vite 等(这也就是为什么使用这些框架时需要安装 Node 环境)
对于前端开发经常用的
npm
,它是 NodeJS 包管理和分发工具,其实就相当于是Node
的开源仓库(并且是全球最大的开源仓库)我们可以使用 npm 指令去下载这个仓库里的指定项目进行使用(如运行npm i axios
下载这个仓库里的axios
)当然我们也可以开发自己的插件项目通过 npm 指令上传到这个仓库里
👉Node.js 的由来
Node.js
基于 V8 引擎,而 V8 其实是 Google 发布的开源 JavaScript 引擎,本身是用于 Chrome 浏览器的 js 解释部分,但是总有大佬不按套路出牌,Node 之父 Ryan Dahl 就把这个 V8 搬到了服务器上,用于做服务器的软件
Node.js
发布于 2009 年 5 月,经过十几年的发展,它已经成为前端中顶梁柱的存在,就算你不需要它进行服务端开发,它也存在于你开发过程中的方方面面,如前面提到的Vue
,React
,Webpack
👉Node.js 的特性
Node.js
贯穿于客户端(如Vue
这类框架的底层依赖)和服务端(如后端开发)Node.js
的语法完全就是javascript
和ES6
的语法Node.js
具有超强的高并发能力,能够实现高性能服务器开发周期短、开发成本低、学习成本低
单论后端开发,Node.js
作为JavaScript
的运行环境的性能虽不能与Java
这类编译语言相比,但它独有的特性完全可以弥补这性能的差距,甚至能够进行超越!这也就是为什么它能够发展如此之快,能够受到越来越多人青睐的原因!
看到这里你可能已经明白,为什么我会说Node
是前端到全栈的必经之路
二、浏览器环境与 Node 环境对比
看图:
图画的不好,凑合着看(操作系统包括网卡/硬盘/本地文件等等,一般是 windows 或 max 或 linux 等等)
从图上看,好像Node
环境就只是浏览器环境的一部分,但其实不然,在浏览器环境中我们很难触控到操作系统那一层,这是因为具有浏览器安全级别的限制(不限制的话,浏览器上的网页就能直接操控操作系统,这还能了得?)
Node.js 作为 JavaScript 的服务端运行环境,它可以解析 JavaScript 代码(没有浏览器安全级别的限制),并能够为其提供很多系统级别的 API,如:
系统文件的读写(
fs
)系统进程的管理(
process
)网络通信 (
HTTP/HTTPS
)等等
这些将在之后的文章中一一讲解,赶快关注博主追更吧!
但这也同样代表在Node.js
中我们无法使用浏览器提供的 API,如window
对象,更不能操作DOM
元素
三、搭建 Node 环境
如果你曾使用过 npm,或者前端框架,相信你已经搭建好了 Node 的环境,这里对没有搭建过的朋友们再次演示一下:
打开 Node 官网:https://nodejs.org/zh-cn/
推荐下载这个长期维护的稳定版本,下载完成后一路Next
安装即可
之后在任意位置终端运行: node -v
出现版本号了就代表我们已经安装成功了
我这里安装的比较久了,所以版本号会比较老,不影响使用
四、体验 Node 模块化开发
在一个文件夹内随便建两个js
文件,如下:
因为Node
的语法就是JavaScript
的语法,所以使用Node
进行模块化开发的方式依旧是使用CommonJS
或ES Modules
,这里直接就进行演示,不再细说
👉CommonJS 方式
Node
默认是CommonJS
方式:
在文件夹终端运行node js文件路径
命令就能使用node
来运行指定的js
文件,console.log
打印结果在终端进行显示
每次修改main.js
文件后需要重新运行命令node .\main.js
执行main.js
文件,这显然不太方便,我们可以安装nodemon
这个插件来帮我们自动运行:
之后使用nodemon
运行main.js
:
其它的导出语法:
👉ES Modules 方式
因为node
默认是使用CommonJS
规范,所以我们在使用ES Modules
时需要进行配置一下
先在文件夹下运行npm init
生成package.json
文件:
运行npm init
后会一个个的让你输入信息,按照上图提示填即可,最后生成的package.json
文件如下:
我们在 package.json
中加上一行 "type": "module",
即可切换使用ES Modules
方式,这时就不能再使用CommonJS
方式了(二选一)
不太建议使用
ES Modules
,因为npm
仓库里的包大多遵循的是CommonJS
规范,如果你使用ES Modules
,去下载这些包时很可能会出现不兼容
语法:
结语
只学习
Node
,并不能让你真正的发展为全栈大佬,学习Node
只是让前端人员能够非常快,非常丝滑的过渡到全栈,为之后的学习发展奠定基础,如果想要成为真正的全栈大佬,像Java
这类的编译语言以及一些其它方面的技术肯定还是要学习的
这篇文章主要介绍了一下什么是Node
,以及Node
环境的配置,之后我们就将开始深入去学习Node
了,关注博主,学习Node
不迷路!
如果本篇文章对你有所帮助,还请客官一件四连!❤️
版权声明: 本文为 InfoQ 作者【海底烧烤店ai】的原创文章。
原文链接:【http://xie.infoq.cn/article/9412a78765000a01b03871622】。文章转载请联系作者。
评论