经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » HTML5 » 查看文章
nodeJS从入门到进阶(一)
来源:cnblogs  作者:smile_or  时间:2019/8/28 8:51:16  对本文有异议

一、Node.js基础知识

1、概念

  • 简单的说 Node.js 就是运行在服务端的 JavaScript。
  • Node.js 是JavaScript的运行环境
  • Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型,使其轻量又高效。

    2、安装使用

  • 官网下载地址:http://nodejs.cn/

    nodeJS5个基本对象:

  • 1、require 引入模块
  • 2、export 导出对象
    • 语法:
    1. 1export.属性 = 值;
    2. 2export.方法名 = 函数;
    • 注意:
    1. 1exportmodule对象的引用 export == module.export (指向同一个内存空间)
    2. 2exportmodule.export的引用, 不能改指向,只能添加属性和方法
    3. 3module.export才是真正的暴露对象,指向哪里就暴露哪里-----推荐使用
  • 3、module 模块对象
    module.export module.export.属性 = 值; module.export.方法名 = 函数; module.export = 对象或函数 module.id 模块id,模块名称 module.parent 模块父级 module.filename 模块文件名和路径 module.children 子模块列表 module.paths 模块查找路径,如果当前目录找不到node_modules就去上一级目录找,直到根目录
  • 4、__filename 当前js文件的绝对路径
  • 5、__dirname 当前js文件所在文件夹绝对路径

    npm包管理器(node Package Manager)

  • package.json是node.js的项目描述文件,以json格式的形式描述项目
  • 创建package.json文件 ----> npm init npm init -y ---->自动全部yes创建
  • package.json常用属性
    name: 项目名称 version:版本号 description:项目描述 main:主模块 dependencies:项目依赖 devDependencies :开发时依赖 scripts:脚本命令,可以使用npm命令执行 license:开源协议
  • npm常用指令:
    npm install <包的名称> i--->install npm i <包的名称>@版本号 //安装指定版本 npm i <包的名称> -g全局安装 -S(save)写入项目依赖列表 -D(dev)写入开发依赖列表 npm search <包的名称> //搜索包 npm view <包的名称> //查看包 npm uninstall <包的名称> //卸载包 npm update <包的名称> //更新包

    cnpm (淘宝镜像)

  • npm install -g cnpm --registry=https://registry.npm.taobao.org

    nodeJS回调函数

  • 回调函数机制:
    • a.定义一个普通函数
    • b.将函数作为参数传入另一个函数(调用者)
    • c.调用者在执行过程中根据时机和条件决定是否调用函数
  • 回调函数用途:
    • 通常用于在达到某个时机或条件时,需要执行代码的情况,使用回调函数

同步和异步

  • 同步:上一行执行完成后,下一行才能得到执行
  • 异步:将比较复杂的任务以任务线程实现,不用等上一句执行完成,下一句也能执行。
  • 异步的三种实现方式:
    • (1) 回调函数
      回调函数不一定是异步(forEacch),异步一定有回调函数
    • (2) 事件 (针对服务器端的事件)
      事件源.on('事件名称',回调函数)
    1. /* 开启一个服务器*/
    2. var http = require('http');
    3. // 建立服务器
    4. var app = http.createServer(function(request, response) {
    5. response.writeHead(200, {
    6. "Content-Type": "text/plain"
    7. });
    8. response.end("Hello world!");
    9. });
    10. //启动服务器
    11. app.listen(80,function(){
    12. console.log('服务器已运行')
    13. })
    • (3) promise 承诺对象
    1. /*
    2. 什么是promise?
    3. promise是es6中新增的承诺对象,用于对异步的操作进行消息的传递
    4. promise的状态?
    5. Pending 等待中
    6. Resolved 成功
    7. Rejected 失败
    8. Pending => Resolved
    9. Pending => Rejected
    10. promise 有什么用?
    11. promise可以传递异步消息
    12. 由于异步的返回结果时间顺序不可控,所以需要使用promise来统一控制输出结果
    13. */
    14. var promise = new Promise(function(resove,reject){
    15. resolve()
    16. })
    17. //调用对象
    18. promise.then(res>{
    19. //成功的回调
    20. }).catch(err=>{
    21. //失败的回调
    22. })
    23. //利用promise对象的all方法可以实现手动调整输出顺序,相当于把异步变为同步
    24. Promise.all([p1,p2]).then(datas=>{
    25. //返回数组
    26. })

二、Buffer缓存区和文件模块

1、Buffer缓存区

概念

  • 在内存中开辟了一个临时区域,用于存放我们需要运算的字节码

    创建缓存区

  • 创建指定长度的缓存区
  1. var buf = new Buffer(大小) //创建5个字节的缓存区
  2. buf.write('a') //存入一个字节 转成16进制 的Ascall码的61 在node中默认使用utf-8编码,一个中文3个字节
  • 按指定的数组编码创建缓存区
  1. var buf = new Buffer([十进制编码]) //数字小可以
  • 按指定字符创建缓存区
  1. var buf = new Buffer('字符串')

写入缓存区

  1. buf.write('字符串')

读缓存区

  1. buf.toString()

复制缓存区

  1. buf.copy(buf2)

2、文件模块(fs)

读取文件

  • 由于nodejs是服务端程序,必须要有文件读写操作,在客户端没有这样的功能
  • 文件读写有两种方式:
    • 直接读取:
      • 将硬盘上的所有内容全部读入内存以后才触发回调函数
      • 两种写法:
        异步:定义一个回调函数,接收读取到的内容 fs.readFile('文件路径',(err,data)=>{}) 同步:几乎所有fs的函数都有同步版本,只需在异步版本后面加Sync即可 (Async:异步) fs.readFileSync('文件路径')
    • 流式读取:
      • 将数据从硬盘中读取一节就触发回调函数,实现大文件操作

        写文件

  • 同步版本
  1. fs.writeFileSync('文件名''数据')
  • 异步版本
  1. fs.writeFile('文件名''数据'funciton(err){/*写完文件以后执行的代码*/})

读取文件信息

  1. fs.stat('文件名',function(err,state){
  2. //state时文件信息对象,包含了常用的文件信息
  3. //size: 文件大小,单位字节
  4. //mtime: 文件修改时间
  5. //birthtime 文件创建时间
  6. //方法
  7. .isFile() //判断当前查看的对象是不是一个文件
  8. .isDirectory() //判断是不是一个目录
  9. })

删除文件

  1. fs.unlink('文件名',function(err){})

需求:填写代码实现删除一个非空目录

  • 删除空目录
  1. fs.rmdir()
  • 读取目录中的文件及文件夹列表
  1. fs.readdir()
  • 读取每一个文件夹的详细信息
  1. fs.stat()
  • 判断如果是文件
  1. fs.unlink()
  • 判断如果是目录
  1. //递归调用自己
  • 删除空目录
  1. fs.rmdir()

流式读取

  • 流:什么是流
    • 所有互联网的数据都是以流的方式,流式一组有起点有终点的数据传输方式
  • 流的操作:
    • 流式读取文件
    1. //可读取数据的流
    2. var fs = require("fs");
    3. var data = '';
    4. // 创建可读流
    5. var readerStream = fs.createReadStream('input.txt');
    6. // 设置编码为 utf8。
    7. readerStream.setEncoding('UTF8');
    8. // 处理流事件 --> data, end, and error
    9. readerStream.on('data', function(chunk) {
    10. data += chunk;
    11. });
    12. readerStream.on('end',function(){
    13. console.log(data);
    14. });
    15. readerStream.on('error', function(err){
    16. console.log(err.stack);
    17. });
    18. console.log("程序执行完毕");
    • 以流的方式写文件
    1. //可写入数据的流
    2. var fs = require("fs");
    3. var data = 'hello world';
    4. // 创建一个可以写入的流,写入到文件 output.txt 中
    5. var writerStream = fs.createWriteStream('output.txt');
    6. // 使用 utf8 编码写入数据
    7. writerStream.write(data,'UTF8');
    8. // 标记文件末尾
    9. writerStream.end();
    10. // 处理流事件 --> data, end, and error
    11. writerStream.on('finish', function() {
    12. console.log("写入完成。");
    13. });
    14. writerStream.on('error', function(err){
    15. console.log(err.stack);
    16. });
    17. console.log("程序执行完毕");
    • 管道流
      管道提供了一个输出流到输入流的机制。通常我们用于从一个流中获取数据并将数据传递到另外一个流中

      ```javascript
      var fs = require("fs");

      // 创建一个可读流
      var readerStream = fs.createReadStream('input.txt');

      // 创建一个可写流
      var writerStream = fs.createWriteStream('output.txt');

      // 管道读写操作
      // 读取 input.txt 文件内容,并将内容写入到 output.txt 文件中
      readerStream.pipe(writerStream);

      console.log("程序执行完毕");
      ```
    • 链式流
    1. //压缩文件
    2. var fs = require('fs');
    3. var zlib = require('zlib');
    4. // 压缩 input.txt 文件为 input.txt.gz
    5. fs.createReadStream('input.txt')
    6. .pipe(zlib.createGzip())
    7. .pipe(fs.createWriteStream('input.txt.gz'))
    8. console.log("文件压缩完成。");
    9. //解压文件
    10. var fs = require("fs");
    11. var zlib = require('zlib');
    12. // 解压 input.txt.gz 文件为 input.txt
    13. fs.createReadStream('input.txt.gz')
    14. .pipe(zlib.createGunzip())
    15. .pipe(fs.createWriteStream('input.txt'));
    16. console.log("文件解压完成。");

    三、常用模块与网络爬虫

    1、常用模块

    path模块

  • 格式化路径
  1. path.nomalize(p)
  • 拼接路径(将多个字符串拼接成一个完整路径)
  1. /*使用path.jon拼接文件路径和 连接符 拼接优点
  2. 1.自动帮我们添加路径分隔符(根据当前操作系统)
  3. 2.自动改正错误的路径分隔符
  4. */
  5. path.join(path1,path2)
  6. let url = path.join(__dirname,path1); //常用
  • 返回路径中文件夹部分
  1. path.dirname(p)
  • 返回路径中文件部分(文件名和扩展名)
  1. path.basename(p)
  • 返回路径中文件的后缀名
  1. path.extname(p)
  • 返回路径字符串的对象。
  1. path.parse(path)
  • 从对象中返回路径字符串,和parse相反
  1. path.format(path)

url模块

  • 什么是url?
    • url是全球统一资源定位符,对网站资源的一种简洁表达式,简称网址
  • url的构成
    • 完整
      协议://用户名:密码@主机名.名.域:端口号/目录名/文件名.扩展名?参数名=参数值&参数名2=参数值2#hash
    • 常见
      协议://主机名.名.域/目录名/文件名.扩展名?参数名=参数值&参数名2=参数值2#hash
  • node.js的url模块
    • 在node.js中提供了两套给予url进行处理的API功能
    • url模块 和 (WHATWG URL标准模块)

      http模块

  • http协议
  • 软件开发模式
    • 单机模式
    • C/S模式 (Client / Server)
    • B/S模式 (Brower / Server)
  • http模块
    -get方法
    get方法用于模仿客户端从服务器获取数据
    javascript var http = require('http'); http.get('url',function(res){ //res 是返回对象,接收到服务器响应的所有内容 res.on("data",function(a){ a //以流的方式获取数据 //每节64kb }) })

    2、网络爬虫

    概念

  • 是一种自动获取网页内容的程序

    实现思路

  • 打开网页内容,查看源代码,分析需要获取的内容规律
  • 编写代码,打开网页,获取html源代码
  • 通过正则表达式提出所需要的内容
  • 遍历数据,批量获取所需要的内容

-----------------------end---------------------------

原文链接:http://www.cnblogs.com/sgs123/p/11417534.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号