赞
踩
Node.js是一个能够在服务器端
运行JavaScript
的开放源代码、是一个跨平台JavaScript运行环境。
node.js就是使用javascript编写,并且运行在服务器,也就是说node.js实现了使用js来开发后端
。
用户请求和响应的过程:
Node.js的产生原因要追溯到服务器的阻塞问题:
传统服务器每次产生一个请求,就对应着一个线程。
那么就有一个问题:请求的速度由用户决定,响应的速度也可以通过提升带宽等方法比较容易的提升速度。但是I/O的输入输出速度是比较难提升的。而每一个请求就会产生一个线程,数据请求又比较慢就会出现有很多线程再缓存中等待,就会造成大量的内存浪费。所以使用Node.js编写的服务器采用单线程
模式,即不管产生多少请求就只有一个线程,这样就可以节省空间,大大降低了成本。
我们常说JS是单线程的,这也与它运行在nodejs上的有关。
Node采用Google开发的V8引擎
运行js代码,使用事件驱动、非阻塞和异步模型等技术来提高性能,可优化应用程序的传输量和规模。
Nodejs是基于V8引擎
,V8是Google发布的开源JavaScript引擎,本身就是用于Chrome浏览器的js解释部分,但是Ryan Dahl鬼才般地,把这个V8搬到了服务器上,用于做服务器的软件。
Node大部分基本模块都用JavaScript
编写。在Node出现之前,JS通常作为客户端程序设计语言使用,以JS写出的程序常在用户的浏览器上运行。Node出现之后,JS可以作为服务端语言使用,运行在服务器。
Node.js的单线程
是Node.js的一个最大的优点,但是同时也是它的缺点。
因为毕竟是单线程,如果请求太多会处理不过来的,所以我们一般情况下采用分布式的方法来弥补这个缺点。分布式是指采取多个服务器,node.js对服务器的要求不高,所以不必担心价格问题。(同时也可以使用cluster模块,使Node.js变成多线程。)
nodejs编写的就是服务器,所以服务器有的作用它都有,如:
官网:https://nodejs.org/en/
中文官网:http://nodejs.cn/download/
以官网为例:
点击下载:
下载完有一个.msi文件,双击进行安装即可。
如果安装.msi文件出现问题可以尝试在终端输入:
msiexec /package +msi文件路径+文件名.msi
查看node是否安装完成:
在任意文件夹目录按住shift键同时点击右键,出现了在此处打开PowerShell
说明安装成功。
也可以cmd在终端直接输入node,进行验证
配置完成环境变量之后再终端输入node
,就进入了node的编写:
node.js的第二种运行方式:
)
node 文件名
,就可以运行相应的node代码了console.log("hello")
var a =123
var b =456
console.log(a+b)
法一:终端运行
打开Vscode的终端
在终端输入:node 文件路径\文件名
法二:右键Run Code
右键Run Code即可运行代码
和浏览器相比node.js环境中是没有DOM和BOM的
引入了一些服务端特性
fs模块
),读写文件。net、http
等模块,用于实现底层的网络通信。在浏览器环境下这些通常是浏览器完成的Buffer
模块,提供更好的二进制数据处理能力。本地系统命令来控制操作系统的进程
,浏览器环境的JavaScript由于安全限制不能这样做。同时Node.js可以开启子进程,并与子进程进行简单的通信。模块化编程:Node.js支持使用CommonJS
进行模块化编程,这使得后端代码更加整洁清晰(CommonJS语法是专门为JS服务端环境提供的语法)。虽然现代的浏览器也开始支持ES6模块
,但在历史上这一直是一个差异之处,在ES5及其之前的JavaScript版本中,并没有原生的模块系统。
模块化是指js文件可以进行导入导出。模块化可以将程序代码分成一个个较小地相对独立的单元(模块),每个模块都有特定的功能,并且可以被其他模块引用。模块化编程可以提高代码的可读性、可维护性、重用性。
eg:(使用的是ES6模块的语法)
myModule.js
export function myFunction() {
return 'Hello, world!';
}
anotherModule.js
import { myFunction } from './myModule';
console.log(myFunction());
这就是模块化编程。
commonJs模块和ES6模块的区别:
在运行时加载
,而ES6模块是在编译时就解析完成依赖关系
。Webpack
和Babel
进行打包构建才能应用在浏览器端。ES6模块对于新版浏览器兼容性较好,旧版浏览器则需要借助Babel
进行转译。<script>
标签引用,但是需要添加type = module
属性,这会告诉浏览器你的脚本是一个JavaScript模块,而非一个传统的全局作用域的脚本,type="module"的脚本默认采用异步加载(相当于在<script>
标签上加了一个async属性)。模块的异步加载和同步加载:https://blog.csdn.net/mantou_riji/article/details/137072904
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。