js异步解决方案-基于nodejs
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了js异步解决方案-基于nodejs,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1989字,纯文字阅读大概需要3分钟。
内容图文
详解js异步的解决方案:promise,generator,async/await
- es6之前解决方案:
- 回调函数
//引入fs模块 var fs = require("fs"); fs.readFile("test.txt",function(err,res) { //执行回调函数 console.log(res.toString()); })
- 发布订阅模式(先有人订阅事件,事件完成后发布者通知订阅者)
const fs = require("fs"); // nodejs 文件模块(用于操作文件的模块) const event = require("events"); // nodejs 的事件模块 const readFileEvent = new event.EventEmitter(); //创建事件对象 // 监听事件,订阅 readFileEvent.on("read1",(data) => { let file1Data = data; // 根据读取到的test.txt文件的内容为地址,读取test2.txt文件的内容。 fs.readFile(file1Data.toString(),(err,data) => { readFileEvent.emit("read2",data) }) }) // 绑定文件test2.txt读取成功时的处理函数 readFileEvent.on("read2",(data) => { console.log(data.toString()); }) // 读取test.txt的内容 fs.readFile("./test.txt",(err,data) => { //触发事件,发布 readFileEvent.emit("read1",data) })
问题:回调函数嵌套,代码结构混乱
- 回调函数
- es6版本
- promise
const fs = require("fs"); // nodejs 文件模块(用于操作文件的模块) //promise有两个参数 new Promise((resolve,reject)=>{ fs.readFile("./test.txt",(err,data) => { let result = data.toString(); resolve(result); }) }).then((res)=>{ console.log(res) },()=>{})
- Generator
const fs = require("fs"); // nodejs 文件模块(用于操作文件的模块) let t = readfile(); function* readfile(){ let res = yield fs.readFile("test.txt",(err,data)=>{ t.next(data.toString()) }) res = yield fs.readFile(res,(err,data)=>{ t.next(data.toString()) }) res = yield fs.readFile(res,(err,data)=>{ t.next(data.toString()) }) console.log(res); } t.next();
- promise
-
es7------async/await写法
const fs = require("fs"); // nodejs 文件模块(用于操作文件的模块) const util = require("util"); //await后面要是promise,所以使用util包转化为promise const readAsync = util.promisify(fs.readFile); async function readThreeFile() { var res = "" res = await readAsync("test.txt"); res = await readAsync(res.toString()); res = await readAsync(res.toString()); console.log(res.toString()); } readThreeFile();
内容总结
以上是互联网集市为您收集整理的js异步解决方案-基于nodejs全部内容,希望文章能够帮你解决js异步解决方案-基于nodejs所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。