使 ES6/7 特性 开发 Node 项 2015/11/ 21 李成银
使⽤用 ES6/7 特性 开发 Node 项⺫⽬目
2015/11/21李成银
关于我• 李成银@奇舞团 • 7 年⼯工作经验 • ThinkJS 作者 • 擅⻓长⼯工程化解决⽅方案 • https://github.com/welefen
⼤大纲• 异步回调问题 • ⾃自动更新问题 • ThinkJS 介绍
缩写• ES6:ECMAScript 6,ECMAScript 2015 • ES7:ECMAScript 7 • 编译:转译 • Node: Node.js node.js
Node 特点• ⾼高并发 • 事件驱动 • IO 密集型
异步问题
异步处理⽅方式• callback • Promise • ES6 generators • ES7 async functions
Callback
callback
callback
Promise
Promise
Promise
Callback => Promise
Promise 的问题• this 指向问题没有解决 • 局部变量需要借助外层的临时变量才能跳跃向后传递 • ⽆无法直接跳过中间某些环节 • 隐藏错误
Generators
Generators
• 使⽤用 function * 和 yield • 是迭代器的⼀一个⼦子类型
Generators
Generators 的问题• 语义上不易理解 • 需要借助执⾏行器 • ⽆无法和 Arrows ⼀一起使⽤用 • yield 和 yield * • function * 和 * method
Async functions
Async functions
Async functions
• 基于 Promise • 返回 Promise • 使⽤用 async/await 更加语义性 • ⽀支持和 Arrows ⼀一起使⽤用 • 不⽤用借助第三⽅方模块
Async functions 错误捕获
try/catch 捕获错误
Async functions 错误捕获
特定值判断是否有错误
Async functions 并⾏行处理
Async functions 问题
• Stage: Proposal • ⺫⽬目前还没有⽀支持的 Runtime
https://github.com/facebook/regenerator
编译带来的问题• ⽂文件修改后如何⾃自动编译
• 如何精准定位报错信息--watch
--retain-lines
• 如何断点调试只能断点调试编译后的代码
使⽤用更多的特性• class • Arrows • Enhanced Object Literals • Template Strings • Default + Rest + Spread • …
⽆无需担⼼心当前的 Node 环境是否⽀支持
性能如何?
class
generators
⾃自动更新问题
fs.watch?chokidarnodemon
⽆无法保存临时数据
更好的解决⽅方案• 监听⽂文件修改变化 • 热更新修改的⽂文件 • 以及依赖⽂文件
require.cache
cache 格式
重写 require ⽅方法
lib/module.js
清除缓存
2014/09/22 发布 1.0 版本2015/10/30 发布 2.0 版本
Async functions
Generators
Promise
特性• ⾃自动编译、⾃自动更新 • 3 种项⺫⽬目模式:mini、normal、module • 3 种项⺫⽬目环境:development、testing、production • 3 种运⾏行环境:ES5、ES6/7->ES5、ES6
更多特性•⽀支持 Mysql,MongoDB,Redis 数据库 • ⽀支持 socket.io,SockJS 等 WebSocket库 • ⽀支持命令⾏行执⾏行和定时任务 • ⽀支持国际化和多主题 • ⽀支持 Middleware 和 Adapter • ⽀支持 __before,__after,__call • ⽀支持⾃自动创建 REST API • …
稳定性和性能• 1500+ 测试⽤用例,95% • 完善的⽂文档,中⽂文/英⽂文,PDF • 2000+ commits
• https://www.thinkjs.org • https://github.com/75team/thinkjs • QQ 交流群:339337680
¥5000/年奖励社区贡献者
4 + 2
ThinkJS 微信红包群
谢谢⼤大家