日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
8個寫JavaScript代碼的小技巧

在編碼時還需要保持代碼整潔,平時注意積累在編碼時所使到的技巧,并關(guān)注 JavaScript 的新增特性。

目前創(chuàng)新互聯(lián)公司已為千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)頁空間、網(wǎng)站托管、服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計、新區(qū)網(wǎng)站維護等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

1. 生成指定區(qū)間內(nèi)的數(shù)字

有時候需要創(chuàng)建在某個數(shù)字范圍內(nèi)的數(shù)組。比如在選擇生日時。以下是最簡單的實現(xiàn)方法。

 
 
 
  1. let start = 1900, 
  2.     end = 2000; 
  3. [...new Array(end + 1).keys()].slice(start); 
  4. // [ 1900, 1901, ..., 2000] 
  5.  
  6. // 也可以這樣,但是大范圍結(jié)果不穩(wěn)定 
  7. Array.from({ length: end - start + 1 }, (_, i) => start + i); 

2. 把值數(shù)組中的值作為函數(shù)的參數(shù)

有時候我們需要先把值放到數(shù)組中,然后再作為函數(shù)的參數(shù)進行傳遞。使用 ES6 語法可以只憑借擴展運算符(...)就可以把值從數(shù)組中提取出來:[arg1,arg2] => (arg1,arg2)。

 
 
 
  1. const parts = { 
  2.   first: [0, 2], 
  3.   second: [1, 3], 
  4. }; 
  5.  
  6. ["Hello", "World", "JS", "Tricks"].slice(...parts.second); 
  7. // ["World", "JS", "Tricks"] 

這個技巧在任何函數(shù)中都適用,請繼續(xù)看第 3 條。

3. 把值數(shù)組中的值作為 Math 方法的參數(shù)

當需要在數(shù)組中找到數(shù)字的最大或最小值時,可以像下面這樣做:

 
 
 
  1. // 查到元素中的 y 位置最大的那一個值 
  2. const elementsHeight =  [...document.body.children].map( 
  3.   el => el.getBoundingClientRect().y 
  4. ); 
  5. Math.max(...elementsHeight); 
  6. // 輸出最大的那個值 
  7.  
  8. const numbers = [100, 100, -1000, 2000, -3000, 40000]; 
  9. Math.min(...numbers); 
  10. // -3000 

4. 展平嵌套數(shù)組

Array 有一個名為 Array.flat 的方法,它需要一個表示深度的參數(shù)來展平嵌套數(shù)組(默認值為 1)。但是如果你不知道深度怎么辦,這時候只需要將 Infinity 作為參數(shù)即可。另外還有一個很好用的 flatMap 方法。

 
 
 
  1. const arrays = [[10], 50, [100, [2000, 3000, [40000]]]]; 
  2. arrays.flat(Infinity); 
  3. // [ 10, 50, 100, 2000, 3000, 40000 ] 

5. 防止代碼崩潰

如果在代碼中存在不可預(yù)測的行為,后果是難以預(yù)料的,所以需要對其進行處理。

例如當你想要獲取的屬性為 undefined 或 null 時,會得到 TypeError 錯誤。

如果你的項目代碼不支持可選鏈( optional chaining)的話,可以這樣做:

 
 
 
  1. const found = [{ name: "Alex" }].find(i => i.name === 'Jim'); 
  2. console.log(found.name); 
  3. // TypeError: Cannot read property 'name' of undefined 

可以這樣避免

 
 
 
  1. const found = [{ name: "Alex" }].find(i => i.name === 'Jim') || {}; 
  2. console.log(found.name); 
  3. // undefined 

不過這要視情況而定,對于小規(guī)模的代碼進行處理完全沒什么問題。不需要太多代碼就可以處理它。

6. 傳參的好方法

在 ES6 中可以把 模板字面量(Template literal) 當作是不帶括號的函數(shù)的參數(shù)。這在進行格式化或轉(zhuǎn)換文本的時非常好用。

 
 
 
  1. const makeList = (raw) => 
  2.   raw 
  3.     .join() 
  4.     .trim() 
  5.     .split("\n") 
  6.     .map((s, i) => `${i + 1}. ${s}`) 
  7.     .join("\n"); 
  8.  
  9. makeList` 
  10. Hello, World 
  11. Hello, World 
  12. `; 
  13.  
  14. // 1. Hello 
  15. // 2. World 

7. 像變戲法一樣交換變量的值

通過解構(gòu)賦值語法,可以輕松地交換變量。

 
 
 
  1. let a = "hello"; 
  2. let b = "world"; 
  3.  
  4. // 錯誤  
  5. a = b 
  6. b = a 
  7. // { a: 'world', b: 'world' } 
  8.  
  9. // 正確  
  10. [a, b] = [b, a]; 
  11. // { a: 'world', b: 'hello' } 

8. 遮蔽字符串

某些時候我們需要遮蔽字符串的一部分,當然不只是對密碼做這種操作。下面代碼中通過 substr(-3) 得到字符串的一部分,即從字符串末尾開始往前 3 個字符,然后再用你喜歡的字符填充剩余的位置(比如說用 *)

 
 
 
  1. const password = "hackme"; 
  2. password.substr(-3).padStart(password.length, "*"); 
  3. // ***kme 

網(wǎng)站欄目:8個寫JavaScript代碼的小技巧
地址分享:http://www.5511xx.com/article/dhhgces.html