欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

JavaScript的技巧有哪些

本篇文章給大家分享的是有關(guān)JavaScript的技巧有哪些,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

成都服務(wù)器托管,創(chuàng)新互聯(lián)建站提供包括服務(wù)器租用、成都聯(lián)通服務(wù)器托管、帶寬租用、云主機(jī)、機(jī)柜租用、主機(jī)租用托管、CDN網(wǎng)站加速、域名注冊等業(yè)務(wù)的一體化完整服務(wù)。電話咨詢:13518219792

不少人有五年的 JavaScript  經(jīng)驗(yàn),但實(shí)際上可能只是一年的經(jīng)驗(yàn)重復(fù)用了五次而已。完成同樣的邏輯和功能,有人可以寫出意大利面條一樣的代碼,也有人兩三行簡潔清晰的代碼就搞定了。簡潔的代碼不但方便閱讀,還能減少復(fù)雜邏輯和出錯的可能性。

1. 簡化條件表達(dá)式

經(jīng)常碰到這種情況,要判斷某個變量是否為指定的某些值,用常規(guī)的邏輯表達(dá)式會很長。我的做法是把這些值放進(jìn)數(shù)組里:

// 太長的邏輯表達(dá)式 if (x === 'abc' || x === 'def' || x === 'ghi' || x ==='jkl') {     //其他邏輯 } // 簡寫 if (['abc', 'def', 'ghi', 'jkl'].includes(x)) {    //其他邏輯 }

2. 簡化 if ... else

if...else太常用了,以至于很多人都忘了其實(shí)還有其他方式來判斷條件。比如簡單的變量賦值,完全沒必要用這種冗長的語句,一行表達(dá)式就搞定了:

// 新手的寫法 let test= boolean; if (x > 100) {     test = true; } else {     test = false; } // 簡寫表達(dá)式 let test = (x > 10) ? true : false; // 更直接的 let test = x > 10; console.log(test);

三元表達(dá)式可以做復(fù)雜的條件分支判斷,不過犧牲了一些可讀性:

let x = 300, let test2 = (x > 100) ? 'greater 100' : (x < 50) ? 'less 50' : 'between 50 and 100'; console.log(test2); // "greater than 100"

3. 判空并賦默認(rèn)值

Code Review 的時候我經(jīng)常看到這樣的代碼,判斷變量不是null,undefined,''的時候賦值給第二個變量,否則給個默認(rèn)值:

if (first !== null || first !== undefined || first !== '') {     let second = first; } // 簡寫 let second = first || '';

4. 簡寫循環(huán)遍歷

for 循環(huán)是最基本的,但是有點(diǎn)繁瑣??梢杂胒or...in、for...of或者forEach代替:

// Longhand for (var i = 0; i < testData.length; i++)  // Shorthand for (let i in testData) or  for (let i of testData)

數(shù)組遍歷:

function testData(element, index, array) {   console.log('test[' + index + '] = ' + element); }  [11, 24, 32].forEach(testData); // 打印輸出: test[0] = 11, test[1] = 24, test[2] = 32

4. 簡化 switch

這個技巧也很常用,把switch 轉(zhuǎn)換成對象的key-value形式,代碼簡潔多了:

// Longhand switch (data) {   case 1:     test1();   break;    case 2:     test2();   break;    case 3:     test();   break;   // And so on... }  // Shorthand var data = {   1: test1,   2: test2,   3: test };  data[anything] && data[anything]();

5. 簡化多行字符串拼接

如果一個字符串表達(dá)式過長,我們可能會拆成多行拼接的方式。不過隨著 ES6 的普及,更好的做法是用模板字符串:

//longhand const data = 'abc abc abc abc abc abc\n\t'     + 'test test,test test test test\n\t' //shorthand const data = `abc abc abc abc abc abc          test test,test test test test`

6. 善用箭頭函數(shù)簡化 return

ES6 的箭頭函數(shù)真是個好東西,當(dāng)函數(shù)簡單到只需要返回一個表達(dá)式時,用箭頭函數(shù)最合適不過了,return都不用寫:

Longhand: //longhand function getArea(diameter) {   return Math.PI * diameter } //shorthand getArea = diameter => (   Math.PI * diameter; )

7. 簡化分支條件語句

又是你,if...else if...else!跟switch類似,也可以用key-value形式簡化:

// Longhand if (type === 'test1') {   test1(); } else if (type === 'test2') {   test2(); } else if (type === 'test3') {   test3(); } else if (type === 'test4') {   test4(); } else {   throw new Error('Invalid value ' + type); } // Shorthand var types = {   test1: test1,   test2: test2,   test3: test3,   test4: test4 };  var func = types[type]; (!func) && throw new Error('Invalid value ' + type); func();

8. 重復(fù)字符串 N 次

有時候出于某種目的需要將字符串重復(fù) N 次,最笨的方法就是用for循環(huán)拼接。其實(shí)更簡單的方法是用repeat:

//longhand  let test = '';  for(let i = 0; i < 5; i ++) {    test += 'test ';  }  console.log(str); // test test test test test  //shorthand  'test '.repeat(5);

9. 指數(shù)運(yùn)算

能省則省,低碳環(huán)保。

//longhand Math.pow(2,3); // 8 //shorthand 2**3 // 8

10. 數(shù)字分隔符

這是比較新的語法,ES2021 提出來的,數(shù)字字面量可以用下劃線分割,提高了大數(shù)字的可讀性:

// 舊語法 let number = 98234567  // 新語法 let number = 98_234_567

以上就是JavaScript的技巧有哪些,小編相信有部分知識點(diǎn)可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

文章題目:JavaScript的技巧有哪些
網(wǎng)站地址:http://aaarwkj.com/article44/jjjshe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、外貿(mào)建站營銷型網(wǎng)站建設(shè)、定制網(wǎng)站網(wǎng)站導(dǎo)航、虛擬主機(jī)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計(jì)公司
午夜精品一区二区三区在线视频| 日韩欧美一区二区三区不卡在线| 黄色污网站在线观看免费| 超碰免费在线公开97| 国产自拍偷拍自拍偷拍| 亚洲成av人片又粗又长| 日本岛国大片一区二区在线观看| 亚洲欧美av中文日韩二区| 国产精品成人av在线网站| 欧美人与性一区二区三区| 日韩精品中文字幕国产精品| 日本国产福利视频在线观看| 在线看片国产精品自拍| 一区二区三区毛片免费| 中文字幕一区二区精品人妻| 国产精品久久久在线视频| 日本成熟亚洲中文字幕的| 欧美av在线免费观看| 日本爱爱一区二区三区| 国产午夜草莓视频在线观看| 久久国产精品亚洲av四虎| 亚洲色图综合在线观看| 亚洲成av人片乱码午夜| 高清av网站大全网站| 欧美日韩精品在线二区| 最新中文字幕人妻少妇| 欧美日韩一区二区激情在线| 91欧美精品在线视频| 哪里可以看黄色片日韩| 国产精品大白屁股视频| 日本熟妇中文字幕系列| 精品国产欧美成人一区| 日本一区二区三区高清| 日本一区二区三区高清在线| 日本欧美激情在线观看| 国产三级国产精品国产国在线观看| 国产伦理在线观看一区二区| 中文字幕五月婷婷免费| 日本高清中文精品在线不卡| 亚洲一区二区另类视频| 亚洲国产精品中文字幕久久|