亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

ES6 中可以提升幸福度的小功能

2019-11-19 13:20:20
字體:
來源:轉載
供稿:網友

一、變量解構賦值的用途

1)交換變量的值

let x = 1;let y = 2;[x, y] = [y, x]

2)從函數返回多個值

// 返回一個數組function example(){  return [1, 2, 4];}let [a, b, c] = example() // 返回一個對象function example(){  return {    foo:1,    bar: 2  }}let {foo, bar} = example(); 或者 ( {foo, bar} = example() )

3)提取JSON數據

let jsonData = { id:42, status: "OK", data: [867, 5309]};let { id, status, data: number} = jsonData;

4)輸入模塊的指定方法

加載模塊時,往往需要指定輸入的方法,解構賦值使得輸入語句非常清晰

const { SourceMapConsumer, SourceNode } = require("source-map")

5) 數組復制的功能

在es5中,開發者經常使用 concat() 方法克隆數組:

// 在 es5 中克隆數組var colors = [ 'red', 'green', 'blue' ];var clonedColors = colors.concat();console.log(clonedColors); // "[red, green, blue]"

concat() 方法的設計初衷是連接兩個數組,如果調用時不傳遞參數就會返回當前數組的副本。在es6中可以通過不定元素的語法來實現相同的目標:

let colors = [ 'red', 'green', 'blue' ]let [ ...clonedColors ] = colors;console.log(clonedColors); // "[red, green, blue]"

6) 結合Set集合,創建一個無重復元素的數組

function eliminateDuplicates(items) {  return [...new Set(items)]}let numbers = [1, 2, 3, 3, 3, 4, 5];let noDuplicates = eliminateDuplicates(numbers );console.log(noDuplicates ); // [1,2,3,4,5]

7) 使用apply 把兩個數據合并成一個

var arra1 = [{ name: '小智', age: 26}]var arra2 = [{ name: '大智', age: 27}]arra1.push.apply(arra1, arra2)console.log(arra1)

二、函數的用處(常見就不多說了)

1)創建立即執行函數表達式

// es5let person = function(name) { return {  getName: function() {   return name;  } }}('小智');console.log(person.getName()); // 小智

在這段代碼中,立即執行函數表達式創建了一個包含getName() 方法的新對象,將參數 name 作為該對象的一個私有成員返回給函數的調用者。

只要箭頭函數包裹在小括號里,就可以用它實現相同的功能

// es6let person = ((name) => { return {  getName: function() {   return name;  } }})('小智2');console.log(person.getName()); //小智

2.利用參數默認值可以指定某一個參數不得省略,如果省略就拋出一個錯誤。

function throwEmptyError() {  throw new Error('參數不能為空');}function foo(mustBeParams = throwEmptyError() ){  return mustBeParams();}foo() // 參數不能為空

三、擴展對象的功能性讓代碼更加簡潔

1) 可計算屬性名

在es6中,使用方括號可以計算屬性名稱,如

let lastName ='last name';let person = {  "first name": 'Nicholas',  [lastName]: 'Zakas'}console.log(person['first name']); // "Nicholas"console.log(person[lastName]); // Zakas

2) 利用 Object.assign()合并兩個對象

function request(options) { let defaultOptions = {  port: 8000,  type: 'get' } Object.assign(options,defaultOptions); console.log(options)}request({url: 'http://www.baidu.com'})

四、結合es6簡潔函數寫法,高階函數的應用

1) tab 函數

// 此處tap函數接受一個 vaule 并返回一個包含value 閉包函數,該函數被執行const tap = (value) => (fn) => ( typeof(fn) === 'function' && fn(value), console.log(value))

tab函數用處:假設你在遍歷一個來自服務器的數組,并發現數據錯了,因此你想調試一下,看看數組包含了什么,就可以用 tab函數

[1, 2 ,3, 4].forEach((a) => { tap(a)((a)=> {  console.log(a) })});#### 2) once 函數

在很多情況下,我們只需要運行一次給定的函數,發起一次銀行支付請求等,這時就可以用到 once 函數。

const once = (fn) => {  let done = false;  return function () {    return done?undefined:((done=true),fn.apply(this,arguments))  }}const doPayment = once(()=>{ console.log('payment is done')})doPayment(); // payment is doneconsole.log(doPayment()); //undefined#### 3) 函數柯里化的應用

開發者編寫代碼的時候應用的不同階級編寫很多日志,我們可以編寫一個如下的日志函數:

const loggerHelper = (mode, initialMessage, errorMessage, lineNo) => { if (mode === 'DEBUG') {  console.debug(initialMessage,errorMessage + 'at line:' + lineNo) } else if (mode === 'ERROR') {  console.error(initialMessage,errorMessage + 'at line:' + lineNo) } else if (mode === 'WARN') {  console.warn(initialMessage,errorMessage + 'at line:' + lineNo) } else  throw "Wrong mode"}

當開發者需要向控制臺打印Stats.js文件中的錯誤時,可以用如下方式:

loggerHelper("ERROR", "ERROR At Stats.js", "Invalid argument passed", 23);

這樣對于 我們追求完美可讀的程序員來說,可能是不太能接受的,現在用柯里來優化以上代碼,
先簡要說明什么是函數柯里化:

柯里化是把一個多參數函數轉換成一個嵌套的一元函數過程。  

封裝一個把把多參數函數轉制為一元函數的curry函數

let curry = (fn) => { if (typeof fn !== 'function') {  throw Error('No function provided'); } return function curriedFn(...args) {  // 傳入參數是否小于函數參數列表長度,  if (args.length < fn.length) {   return function() {    return curriedFn.apply(null, args.concat([].slice.call(arguments)));   }  }  return fn.apply(null, args) }} let errorLogger = curry(loggerHelper)("ERROR")("ERROR At Stats.js");let debugLogger = curry(loggerHelper)("DEBUG")("ERROR")("Debug At Stats.js");let warnLogger = curry(loggerHelper)("WARN")("Warn")("At Stats.js");// 用于錯誤errorLogger("Error message", 21)// 用于調試debugLogger('Debug message', 233)// 用于警告warnLogger("Warn message", 34); 

現在我們能夠輕松引用上面的柯里化并在各自的上下文中使用它們了。

總結

以上所述是小編給大家介紹的ES6 中可以提升幸福度的小功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美怡红院视频一区二区三区| 国内免费久久久久久久久久久| 国产精品户外野外| 国产精欧美一区二区三区| 欧美裸体xxxx| 日韩精品一区二区三区第95| 国内精久久久久久久久久人| 欧美日韩xxx| 国产女人18毛片水18精品| 69视频在线免费观看| 色视频www在线播放国产成人| 国产精品你懂得| 国产精品久久久久久久久免费看| 日韩经典中文字幕| 成人精品福利视频| 精品亚洲男同gayvideo网站| 久久手机免费视频| 992tv在线成人免费观看| 久久中文字幕在线| 国产精品你懂得| 欧美成年人视频网站欧美| 亚洲第一区中文99精品| 粗暴蹂躏中文一区二区三区| 国产+人+亚洲| 91在线观看免费观看| 久久久久久国产精品久久| 亚洲春色另类小说| 97在线看免费观看视频在线观看| 日韩电影免费观看在线| 欧美一区第一页| 日韩一区二区三区xxxx| 亚洲女人被黑人巨大进入al| 亚洲小视频在线| 国产精品美女免费视频| 蜜臀久久99精品久久久久久宅男| 亚洲高清福利视频| 亚洲精品电影久久久| 国产精品视频免费在线观看| 欧亚精品在线观看| 久久精品99久久久久久久久| 久久精品亚洲热| 日韩在线中文视频| 欧美大片免费观看在线观看网站推荐| 97国产精品视频人人做人人爱| 精品中文字幕在线2019| 欧美午夜激情视频| 国产视频自拍一区| 久久激情视频久久| 美女av一区二区三区| 最近2019好看的中文字幕免费| 久久久久亚洲精品成人网小说| 日韩乱码在线视频| 国模精品一区二区三区色天香| 中日韩美女免费视频网址在线观看| 欧美激情一二三| 久久免费精品日本久久中文字幕| 日韩av在线播放资源| 亚洲新中文字幕| 成人福利在线观看| 亚洲欧美一区二区三区情侣bbw| 久久久久久69| 国产99久久精品一区二区 夜夜躁日日躁| 欧美日本在线视频中文字字幕| 欧美黑人一区二区三区| 午夜精品一区二区三区视频免费看| 欧美激情第一页xxx| 黑人巨大精品欧美一区免费视频| 91精品免费久久久久久久久| 欧美孕妇性xx| 超碰精品一区二区三区乱码| 日本免费一区二区三区视频观看| 亚洲精品少妇网址| 米奇精品一区二区三区在线观看| 国产婷婷成人久久av免费高清| 欧美风情在线观看| 青青草成人在线| 久久久亚洲精品视频| 欧美激情18p| www.美女亚洲精品| 亚洲欧美日本伦理| 欧美成aaa人片免费看| 成人免费淫片视频软件| 亚洲精品电影网| 国产精品免费久久久久久| 日本成人免费在线| 欧美视频中文在线看| 欧美激情亚洲激情| 成人高清视频观看www| 国产成人a亚洲精品| 另类图片亚洲另类| 在线观看日韩欧美| 亚洲视频一区二区三区| 91精品国产自产在线观看永久| 欧美床上激情在线观看| 亚洲欧美日韩精品久久奇米色影视| 久久精品国产欧美亚洲人人爽| 亚洲欧美日韩视频一区| 亚洲精品成人久久| 亚洲视频网站在线观看| xxav国产精品美女主播| 久久精品亚洲国产| **欧美日韩vr在线| 欧美日韩一区免费| 国产亚洲精品一区二555| 国产美女精彩久久| 国内揄拍国内精品少妇国语| 欧美成人精品在线视频| 国产成人欧美在线观看| 亚洲精品欧美日韩专区| 日韩精品免费在线视频| 国产一区二区三区直播精品电影| 亚洲欧美制服第一页| 国产欧美va欧美va香蕉在线| 色yeye香蕉凹凸一区二区av| 国产精品露脸av在线| 亚洲精品电影在线观看| 欧美中文字幕第一页| 亚洲欧美日韩精品久久| 欧美自拍大量在线观看| 成人亚洲欧美一区二区三区| 亚洲中国色老太| 亚洲精品美女在线观看播放| 欧美性猛交xxxx免费看久久久| 国产一区二区三区四区福利| 久久久久久久久综合| 麻豆精品精华液| 亚洲一级黄色片| 91探花福利精品国产自产在线| 日韩视频免费在线| 亚洲精品一区中文字幕乱码| 亚洲最大的网站| 国产精品色婷婷视频| 亚洲精品国产美女| 国产精品久久在线观看| 久久久午夜视频| 精品亚洲夜色av98在线观看| 久久99久久99精品中文字幕| 亚洲变态欧美另类捆绑| 国产成人欧美在线观看| 日韩av电影中文字幕| 欧美色播在线播放| 中文字幕日韩精品在线观看| 国产69精品久久久久9| 欧美极度另类性三渗透| 欧美高清第一页| 久久国产精品偷| 97在线观看免费| 亚洲免费电影在线观看| 久久久女人电视剧免费播放下载| 成人午夜激情网| 欧美大学生性色视频| 欧美激情小视频| 热久久美女精品天天吊色| 91色琪琪电影亚洲精品久久| 日韩激情视频在线播放| 97在线视频精品| 尤物精品国产第一福利三区| 狠狠综合久久av一区二区小说| 久久夜色精品亚洲噜噜国产mv| 日韩经典中文字幕| 日韩欧美中文免费| 欧美一级片在线播放| 亚洲视频自拍偷拍| 国产亚洲欧洲高清一区|