function doSomething(config) { if(config.a) { ... } if(config.b) { ... } if(config.c) { ... }}有更好的写法:
function doSomething({ a, b, c }) { if(a) { ... } if(b) { ... } if(c) { ... }}数组方法
ES6 引入了许多有用的数组方法,例如:
- find(),查找列表中的成员,返回 null 表示没找到
- findIndex(),查找列表成员的索引
- some(),检查某个断言是否至少在列表的一个成员上为真
- includes,列表是否包含某项
const array = [{ id: 1, checked: true }, { id: 2 }];arr.find(item => item.id === 2) // { id: 2 }arr.findIndex(item => item.id === 2) // 1arr.some(item => item.checked) // trueconst numberArray = [1,2,3,4];numberArray.includes(2) // truePromises + Async/Await
如果你在这个圈子里呆了些年头,也许会记得曾经有一个时期我们只有回调,就像这样:
function doSomething(cb) { setTimeout(() => { cb('done') }, 3000)}doSomething((arg) => { console.log('done here', arg);})我们使用回调是因为有些操作是异步的,需要时间来完成 。后来我们有了 promise 库,人们开始使用它 。然后 JavaScript 逐渐加入了对 promise 的原生支持 。
function doSomething() { return new Promise((resolve, reject) => { setTimeout(() => { resolve('done') }, 3000) })}doSomething().then(arg => { console.log('done here', arg);})我们甚至可以这样调用,将 promise 串起来:
getUser() .then(getOrderByUser) .then(getOrderItemsByOrder) .then(orderItems => { // 处理排序后的成员 })后来生活更加美好,我们有了 async/await, 上面一段代码可以这样写:
async function getItems() { try { const user = await getUser(); const order = await getOrderByUser(user); const items = await getOrderItemsByOrder(order); return items; } catch(err) { // 在这里处理错误,建议返回某个值或者重新抛出错误 }}getItems().then(items => { // 处理排序后的成员})模块
差不多任何编程语言都支持模块这一概念,也就是将代码分为多个文件,每个文件是一个自我包含的单元(模块) 。考虑下面的代码:
// math.jsexport function add(a,b) { return a + b; }export function sub(a,b) { return a - b; }export default mult(a,b) => a * b;// main.jsimport mult, { add, sub } from './math';mult(2, 4) // 8add(1,1) // 2sub(1,2) // -1我们在上面用 export 关键字注明了 add 和 sub 这两个结构对任何引入该模块的模块都公开可见 。export default 关键字则注明仅仅 import 模块时得到的结构 。在 main.js 中,我们将导入的 default 命名为 mult,同时指明我们引入 add() 和 sub() 这两个方法 。
箭头函数和字典作用域 this
我在这篇文章中很多地方都用到了箭头函数,它不过是另一种函数表示法 。过去我们只能这么声明函数:
function printArray(arr) { // 具体操作}现在我们也可以这么写:
const printArray = (arr) => { // 具体操作}我们也可以将函数声明写到一行里:
const add = (a,b) => a + b上面的代码表明我们进行操作并返回结果 。我们也可以采用下面的语法返回一个对象:
const create = (a,b) = > ({ x: a, y: b })过去会碰到搞不清 this 是什么的问题 。考虑下面的代码:
let array = [1,2,3];function sum() { this.total = 0; arr.forEach(function(item) { this.total+= item; // 糟糕,`this` 是内层函数的 `this` }) return total;}上面代码中的 this 指向 forEach 内部函数的 this,这可不是我们想要的 。过去我们通过以下方式解决这个问题:
function sum() { this.total = 0; var self = this; arr.forEach(function(item) { self.total+= item; // 这里我们使用 `self`,它能解决问题,但是感觉有点别扭 }) return total;} 箭头函数可以解决问题,再也不用 self 了,现在代码看起来是这样的:
function sum() { this.total = 0; arr.forEach((item) => { this.total+= item; // 一切安好,`this` 指向外层函数 }) return total;}大胜!
结语
我还可以讲讲更多 ES6 方面的内容,不过这篇文章中我只打算介绍我最偏爱的特性 。我觉得你应该从今天开始使用这些特性 。
文章转自:https://segmentfault.com/a/1190000020482546
【十个超级实用的 JS 特性】
推荐阅读
- 10行配置就能实现微服务框架的API访问限流
- 胃疼吃啥药
- 超实用化妆小技巧,学会美翻天
- 老年人青光眼茶饮,疗效其实非常好!
- 为什么店铺认证一直不通过 淘宝店铺实人认证不通过怎么办
- 铁罗汉茶叶品鉴条索壮实 褐绿色 香气扑鼻
- 长沙超级文和友在哪里买单 长沙超级文和友在哪里
- 德丰利达实地考察贵州湄潭投资环境
- 关于龙的真实事件 龙真实存在的证据
- dedecms获取顶级栏目名称、二级栏目名称实现方法
