日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

es6 --- 解构赋值的简洁性

發(fā)布時間:2023/12/10 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 es6 --- 解构赋值的简洁性 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

設(shè)想你有一個工具foo,它可以異步產(chǎn)生兩個值(x和y):

function getY(x) {return new Promise( function(resolve, reject) {setTimeout( function() {resolve( (3*x) -1 );}, 100);}); }function foo(bar, baz) {var x = bar * baz;return getY(x).then( function(y){return [x, y];}); }foo(10, 20) .then(function (msgs) {var x = msg[0];var y = msg[1];console.log(x, y); });// getY:延遲0.1秒返回一個Promise對象,值為 3*x-1; // foo:在等待getY()執(zhí)行完畢后,返回一個Promise數(shù)組

你可能注意到,上述的方法可以用Promise.all來完成:

function foo(bar, baz){var x = bar * baz;return [Promise.resolve(x),getY(X)]; } Promise.all(foo(10, 20) ) .then(function (msgs){var x = msgs[0];var y = msgs[1];console.log(x,y); });// 代碼變得簡潔,邏輯更清晰了..

可以看到Promise.all的then里面有一個var x = msgs[0], var y = msgs[1]…這個操作的開銷有點大…

// by Reginald Braithwaite function spread(fn) {return Function.apply.bind(fn, null); }Promise.all(foo(10, 20) ) .then(spread(function (x, y){console.log(x, y);}) )

可以進(jìn)一步的將spread放入then中

Promise.all(foo(10, 20) ) .then( Function.apply.bind(function(x, y){console.log(x, y);},null) );

誒,回歸主題,使用ES6的解構(gòu)

Promise.all(foo(10, 20) ) .then(function(msgs) {var [x, y] = msgs;console.log(x, y); });

將解構(gòu)應(yīng)用到函數(shù)的參數(shù)中

Promise.all(foo(10, 20) ) .then(function ([x, y]){console.log(x, y); }); // 注:解構(gòu)賦值,一定要好好學(xué),可以簡化你的代碼,使邏輯更加清晰...

參考《你不知道的JavaScript》(中卷)P223~P225

總結(jié)

以上是生活随笔為你收集整理的es6 --- 解构赋值的简洁性的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。