04、NodeJS-文件操作&网络操作

NodeJS: https://github.com/nodejs/node/ 在github中想要查找某个文件,按t;
例如: 在使用fs.createWriteStream时,文档中没有具体方法,就可以通过查看源码,通过源码找对应的构造函数看有哪些属性设置,查看原型有哪些方法可用;

npm中管理的包
npm ls --depth 0 // 即依赖子集为0
$ npm ls --depth 1 // 即依赖子集的第一层

nodemon:监视您的node.js应用程序的任何更改并自动重新启动服务器
nodemon xxx.js // 运行对应文件即可

一、文件监视

  • fs.watchFile(filename[, options], listener(curr,prev))
  //  { persistent: true, interval: 5007 },即表示持续不断监视,时间间隔为5007毫秒
  options:{persistent,interval}

  const target = path.join(__dirname, process.argv[2]);
  fs.watchFile(target, (curr, prev)=>{
      console.log(`curr:${curr.size}; prev: ${prev.size}`);
});

  • fs.watch(filename[,options][,listener])

  • 利用文件监视实现自动 markdown 文件转换
    相关链接:
    Markdown转换: https://github.com/chjj/marked
    同步浏览器端: https://github.com/Browsersync/browser-sync

 思路:
 - 利用fs模块的文件监视功能监视指定MD文件
 - 当文件发生变化后,借助marked包提供的markdown to html功能将改变后的MD文件转换为HTML
 - 将得到的HTML替换到模版中(html = template.replace('{{content}}', html).replace('{{style}}', css);)
 - 利用BrowserSync模块实现浏览器自动刷新 

 markdown的样式有很多可以选择,选取的不同,html结构也会有所不同。
关于github.css主体内容是包裹在div为.vs中:

    
{{content}}
  BrowserSync模块的使用
    1、$ npm install browser-sync // 安装browser-sync
    2、const browserSync = require("browser-sync");  // 导入模块
    3、通过browserSync创建一个文件服务器
    browserSync({
            server: path.dirname(target),  // 文件服务器的目录
            index:indexName // 在开启服务器之后会打开页面,该页面作为网站根目录
    });
    4、当文件修改后,刷新浏览器页面
    browserSync.reload(indexName);  // fileName是完整路径

添加完BrowserSync后,就会在对应目录创建并启动一个服务器,自动打开页面(或手动打开,命令行有提示)http://192.168.1.112:3000 此时是在根目录下,也可以具体访问某个文件http://192.168.1.112:3000/xxx.html

二、文件流

  • 什么是流?
  - 流是程序输入或输出的一个连续的字节序列
  - 文件流、网络流
  - 设备(例如鼠标、键盘、磁盘、屏幕、调制解调器和打印机)的输入和输出都是用流来处理的

  • 文件流
  - 文件流就是以面向对象的概念对文件数据进行的抽象
  - 文件流定义了一些对文件数据的操作方式

  • Node中的流操作
    • fs.createReadStream() 可读流
  读取流常用 API
  Event:data、end、error
  Method: read([size])、pause()、isPause()、resume()、
setEncoding(encoding)、pipe(destination[, options])、unpipe([destination])

  • fs.createWriteStream() 可写流
  Event: error、pipe
  Method:write(chunk[, encoding][, callback])、end([chunk][, encoding][, callback])、setDefaultEncoding(encoding)

案例: 拷贝文件功能

fs-extra文件操作模块 可以是拷贝、删除、创建等操作

三、网络操作

  • NET模块
    在Node中socket通信的一种实现
    let server = net.createServer( (socket) => {  // 当客户端链接时,即会触发

    // client有三个参数: 端口号、IPV4/IPV6、ip
    var client = socket.address();
    // 或直接通过socket.remoteAddress / socket.remotePort 访问到

    // 监听socket,网络流
    socket.on('data', (chunk)=>{

    });
  } );

  // 绑定IP, 监听2017端口
  const port = 2017;
  // server.listen(options[, callback])
  // options { host: '192.168.1.100', port: 80}
  server.listen(port, (err) => {

  });
  // 为了方便操作,命令行方式链接服务端(使用telnet操作): $ telnet 192.168.1.100 2017

  // 简便写法
  // port 端口号, host IP地址
  // net.createServer(socketConneted).listen(port,  host, (err) => { });
  net.createServer(socketConneted).listen({port:port, host: host}, (err) => { });
  function socketConneted(socket){ ... }

  // 创建链接
  const client = net.connect({port: '2017', host:'192.168.1.100'}, ()=>{
    console.log('链接服务器成功');
    client.write('hello ??');
});

  // 监听到数据
  client.on('data', (chunk) => {
    console.log('接收到数据:' + chunk.toString());
})

process.stdin.on('data', (chunk) => {
    // 转成string类型,并且去掉前后空白
    console.log(chunk.toString().trim());
});

案例:简易的聊天室

查看文档是net(http和http是高度封装的,net中更多了解socket通信是怎么的一个过程,如何的一个操作)

作者:西门奄
链接:https://www.jianshu.com/u/77035eb804c3
來源:
著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

你可能感兴趣的:(04、NodeJS-文件操作&网络操作)