node.js基础知识汇总


Posted in Javascript onAugust 25, 2020

一、node介绍

1.node的应用场景

  • 工具类 gulp webpack vite (node可以让js运行在服务器)
  • 可以做服务端 优化ssr
  • 可以做中间层 (解决跨域问题,格式化数据)

2.性能

  • 非阻塞
  • 异步I/O(当这个方法调用完毕后不会立即返回结果)
  • 事件驱动(发布订阅模式)

3.优势

在Java、PHP或者.NET等服务器语言中,会为每一个客户端连接创建一个新的线程。而每个线程需要耗费大约2MB内存。也就是说,理论上,一个8GB内存的服务器可以同时连接的最大用户数为4000个左右。要让web应用程序支持更多的用户,就需要增加服务器的数量,而web应用程序的硬件成本当然就上升了。

NodeJs不为每个客户连接创建一个新的线程,而仅仅使用一个线程。当有用户连接了,就触发一个内部事件,通过非阻塞I/O、事件驱动机制,让Node.js程序宏观上也是并行的。使用Node.js,一个8GB内存的服务器,可以同时处理超过4万用户的连接。

二、node的全局对象和模块

1.global

global是全局对象,可以直接访问里面的属性

里面有:

  • Buffer
  • process
  • setInterval,setTimeout,setImmediate
  • console
  • queueMicrotask

2.模块

  • __dirname
  • __filename
  • exports
  • module
  • require()

三、process常用属性或方法

process.platform 系统

process.kill 杀进程

process.exit 退出进程

process.nextTick node中的微任务 当前执行栈的底部 优先级比promise高

process.cwd() 当前的工作目录,是可变的,看命令在哪里执行 (__dirname当前文件所在的文件夹,此路径不会发生变化)

process.env 环境变量(可以set,例如process.env.NODE_ENV)

process.argv 执行时所带的参数

四、事件环机制

node.js基础知识汇总

重要的三个阶段

timer 存放定时器

poll 轮询处理I/O回调

check setImmediate

如果在 I/O 回调的方法里,setImmediate优先于 timer 执行

应为 poll 接下来是 check

nextTick 算是一个微任务,不在事件环中

在node 11 以上 宏任务与微任务的执行顺序与浏览器一样

五、Buffer

JavaScript 语言自身只有字符串数据类型,没有二进制数据类型。

但在处理像TCP流或文件流时,必须使用到二进制数据。因此在 Node.js中,定义了一个 Buffer 类,该类用来创建一个专门存放二进制数据的缓存区。在 Node.js 中,Buffer 类是随 Node 内核一起发布的核心库。Buffer 库为 Node.js 带来了一种存储原始数据的方法,可以让 Node.js 处理二进制数据,每当需要在 Node.js 中处理I/O操作中移动的数据时,就有可能使用 Buffer 库。原始数据存储在 Buffer 类的实例中。一个 Buffer 类似于一个整数数组,但它对应于 V8 堆内存之外的一块原始内存。Buffer属于global上的属性可以直接被访问,读取文件,写入(二进制)从硬盘中读取的数据都存到内存上,buffer可以和字符串相互转化

定义buffer的三种方式

let buf1 = Buffer.alloc(6);
let buf2 = Buffer.from('珠峰');
let buf3 = Buffer.from([65,66,67]);

buffer中常用的方法

  • buff.toString()
  • buff.fill()
  • buff.slice()
  • buff.copy
  • Buffer.concat()
  • Buffer.isBuffer()
  • indexOf

以上就是node.js基础知识汇总的详细内容,更多关于node.js基础知识的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
原生Js实现按的数据源均分时间点幻灯片效果(已封装)
Dec 28 Javascript
JavaScript对象创建及继承原理实例解剖
Feb 28 Javascript
js弹出对话框方式小结
Nov 17 Javascript
jQuery.form插件的使用及跨域异步上传文件
Apr 27 Javascript
Spring MVC中Ajax实现二级联动的简单实例
Jul 06 Javascript
AngularJs中 ng-repeat指令中实现含有自定义指令的动态html的方法
Jan 19 Javascript
正则 js分转元带千分符号详解
Mar 08 Javascript
VUE实现一个分页组件的示例
Sep 13 Javascript
JSON 数据格式详解
Sep 13 Javascript
vue-cli3环境变量与分环境打包的方法示例
Feb 18 Javascript
JS实现分页导航效果
Feb 19 Javascript
小程序自定义圆形进度条
Nov 17 Javascript
基于JS实现快速读取TXT文件
Aug 25 #Javascript
Vue实现简单的拖拽效果
Aug 25 #Javascript
浅谈JavaScript节流和防抖函数
Aug 25 #Javascript
JS实现拖动模糊框特效
Aug 25 #Javascript
PHP读取远程txt文档到数组并实现遍历
Aug 25 #Javascript
JS轮播图的实现方法2
Aug 25 #Javascript
JS轮播图的实现方法
Aug 24 #Javascript
You might like
十天学会php之第十天
2006/10/09 PHP
Smarty模板快速入门
2007/01/04 PHP
php 数组的一个悲剧?
2011/05/11 PHP
php设计模式 Builder(建造者模式)
2011/06/26 PHP
使用array_map简单搞定PHP删除文件、删除目录
2014/10/29 PHP
php验证码的制作思路和实现方法
2015/11/12 PHP
laravel excel 上传文件保存到本地服务器功能
2019/11/14 PHP
自己的js工具 Cookie 封装
2009/08/21 Javascript
关于this和self的使用说明
2010/08/01 Javascript
js不能跳转到上一页面的问题解决方法
2013/03/01 Javascript
把字符串按照特定的字母顺序进行排序的js代码
2014/01/28 Javascript
js的hasownproperty使用示例
2014/03/02 Javascript
jQuery获得包含margin的outerWidth和outerHeight的方法
2015/03/25 Javascript
jQuery插件MixItUp实现动画过滤和排序
2015/04/12 Javascript
javascript原型模式用法实例详解
2015/06/04 Javascript
分享JavaScript与Java中MD5使用两个例子
2015/12/23 Javascript
jquery基础知识第一讲之认识jquery
2016/03/17 Javascript
纯JS实现图片验证码功能并兼容IE6-8(推荐)
2017/04/19 Javascript
vue中路由参数传递可能会遇到的坑
2017/12/07 Javascript
js实现控制文件拖拽并获取拖拽内容功能
2018/02/17 Javascript
在 Typescript 中使用可被复用的 Vue Mixin功能
2018/04/17 Javascript
vue eslint简要配置教程详解
2019/07/26 Javascript
JS实现简单的表格增删
2020/01/16 Javascript
Webpack的Loader和Plugin的区别
2020/11/09 Javascript
python中List的sort方法指南
2014/09/01 Python
Python的爬虫程序编写框架Scrapy入门学习教程
2016/07/02 Python
详解Numpy中的数组拼接、合并操作(concatenate, append, stack, hstack, vstack, r_, c_等)
2019/05/27 Python
Django网络框架之HelloDjango项目创建教程
2019/06/06 Python
关于tf.nn.dynamic_rnn返回值详解
2020/01/20 Python
使用CSS3实现SVG路径描边动画效果入门教程
2019/10/21 HTML / CSS
伦敦新晋轻奢耳饰潮牌:Tada & Toy
2020/05/25 全球购物
如何实现jdbc性能优化
2012/07/30 面试题
甜点店创业计划书
2014/01/27 职场文书
财务会计毕业生个人求职信
2014/02/03 职场文书
2015年毕业实习工作总结
2014/12/12 职场文书
导游词之山海关
2019/12/10 职场文书