微信小程序 Node.js (基礎七) Stream(流)

微信小程序 Node.js (基礎七) Stream(流)具體操做教程:javascript

Stream 是一個抽象接口,Node 中有不少對象實現了這個接口。 
Stream 有四種流類型: 
- Readable - 可讀操做。 
- Writable - 可寫操做。 
- Duplex - 可讀可寫操做. 
- Transform - 操做被寫入數據,而後讀出結果。 

Stream 對象都是 EventEmitter 的實例。經常使用的事件有: 
- data - 當有數據可讀時觸發。 
- end - 沒有更多的數據可讀時觸發。 
- error - 在接收和寫入過程當中發生錯誤時觸發。 
- finish - 全部數據已被寫入到底層系統時觸發。java

讀取

var fs = require("fs")
var data= ""

var readerStreama = fs.createReadStream("input.txt")
readerStreama.setEncoding('UTF8')

readerStreama.on("data",function(chunk){
data+= chunk;
})

readerStreama.on("end",function(){
    console.log(data);
})

readerStreama.on("error",function(err){
console.log(err.stack)
})

console.log("程序執行完成")
  •  

寫入

var fs = require("fs");
var data = 'www.csdn.net';

// 建立一個能夠寫入的流,寫入到文件 output.txt 中
var writerStream = fs.createWriteStream('output.txt');

// 使用 utf8 編碼寫入數據
writerStream.write(data,'UTF8');

// 標記文件末尾
writerStream.end();

// 處理流事件 --> data, end, and error
writerStream.on('finish', function() {
    console.log("寫入完成。");
});

writerStream.on('error', function(err){
   console.log(err.stack);
});

console.log("程序執行完畢");
  •  

管道流

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("程序執行完畢");
  •  

鏈式流

鏈式是經過鏈接輸出流到另一個流並建立多個對個流操做鏈的機制。鏈式流通常用於管道操做。node

壓縮小程序

var fs = require("fs");
var zlib = require('zlib');

// 壓縮 input.txt 文件爲 input.txt.gz
fs.createReadStream('input.txt')
  .pipe(zlib.createGzip())
  .pipe(fs.createWriteStream('input.txt.gz'));

console.log("文件壓縮完成。");
  •  

解壓縮微信小程序

var fs = require("fs");
var zlib = require('zlib');

// 解壓 input.txt.gz 文件爲 input.txt
fs.createReadStream('input.txt.gz')
  .pipe(zlib.createGunzip())
  .pipe(fs.createWriteStream('input.txt'));

console.log("文件解壓完成。");
  •  

微信小程序 Node.js (基礎八) exports模塊系統微信

一個 Node.js 文件就是一個模塊,這個文件多是JavaScript 代碼、JSON 或者編譯過的C/C++ 擴展。ui

// main.js
var hello = require("./hello")
hello.sayHi()
  •  
// hello.js
exports.sayHi  = function(){
    console.log("Hello World")
}
  •  

// 將對象封裝到模塊中this

function sayHi(){
    this.hi = function(){
        console.log("Hello World")  
    }
}
module.exports = sayHi
  •  
var Hello = require("./hello")
var hello = new Hello()
hello.hi()
相關文章
相關標籤/搜索