自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

9個(gè)極其強(qiáng)大的JavaScript技巧

開發(fā) 前端
所謂 hacker 方法,就是一種不斷改進(jìn)和迭代的構(gòu)建方法。有著 hacker 精神的程序員相信事物總有改進(jìn)的余地,沒有什么是完美的存在。每一段代碼都有進(jìn)一步優(yōu)化的空間,每一個(gè)操作都有更便捷的技巧。

所謂 hacker 方法,就是一種不斷改進(jìn)和迭代的構(gòu)建方法。有著 hacker 精神的程序員相信事物總有改進(jìn)的余地,沒有什么是完美的存在。每一段代碼都有進(jìn)一步優(yōu)化的空間,每一個(gè)操作都有更便捷的技巧。

下面列舉一些非常強(qiáng)大的 JavaScript hack 技巧。

[[359420]]

1. Replace All

我們知道 string.Replace() 函數(shù)只會(huì)替換第一個(gè)項(xiàng)目。

你可以在這個(gè)正則表達(dá)式的末尾添加 /g 來替換所有內(nèi)容。

  1. var example = "potato potato"
  2. console.log(example.replace(/pot/, "tom"));  
  3. // "tomato potato" 
  4. console.log(example.replace(/pot/g, "tom"));  
  5. // "tomato tomato" 

2. 提取唯一值

我們可以使用 Set 對(duì)象和 Spread 運(yùn)算符,創(chuàng)建一個(gè)剔除重復(fù)值的新數(shù)組。

  1. var entries = [1, 2, 2, 3, 4, 5, 6, 6, 7, 7, 8, 4, 2, 1] 
  2. var unique_entries = [...new Set(entries)]; 
  3. console.log(unique_entries); 
  4. // [1, 2, 3, 4, 5, 6, 7, 8] 

3. 將數(shù)字轉(zhuǎn)換為字符串

我們只需使用帶空引號(hào)的串聯(lián)運(yùn)算符即可。

  1. var converted_number = 5 + ""; 
  2. console.log(converted_number); 
  3. // 5 
  4. console.log(typeof converted_number);  
  5. // string 

4. 將字符串轉(zhuǎn)換為數(shù)字

用 + 運(yùn)算符即可。

請(qǐng)注意這里的用法,因?yàn)樗贿m用于“字符串?dāng)?shù)字”。

  1. the_string = "123"
  2. console.log(+the_string); 
  3. // 123 
  4. the_string = "hello"
  5. console.log(+the_string); 
  6. // NaN 

5. 隨機(jī)排列數(shù)組中的元素

每天我都在隨機(jī)排來排去……

  1. var my_list = [1, 2, 3, 4, 5, 6, 7, 8, 9]; 
  2. console.log(my_list.sort(function() { 
  3.     return Math.random() - 0.5 
  4. }));  
  5. // [4, 8, 2, 9, 1, 3, 6, 5, 7] 

6. 展平多維數(shù)組

只需使用 Spread 運(yùn)算符。

  1. var entries = [1, [2, 5], [6, 7], 9]; 
  2. var flat_entries = [].concat(...entries);  
  3. // [1, 2, 5, 6, 7, 9] 

7. 短路條件

舉個(gè)例子:

  1. if (available) { 
  2.     addToCart(); 

只需使用變量和函數(shù)就能縮短它:

  1. available && addToCart() 

8. 動(dòng)態(tài)屬性名稱

我一直以為我必須先聲明一個(gè)對(duì)象,然后才能分配一個(gè)動(dòng)態(tài)屬性。

  1. const dynamic = 'flavour'
  2. var item = { 
  3.     name: 'Coke', 
  4.     [dynamic]: 'Cherry' 
  5. console.log(item);  
  6. // { name: "Coke", flavour: "Cherry" } 

9. 使用 length 調(diào)整大小 / 清空數(shù)組

基本上就是覆蓋數(shù)組的 length。

如果我們要調(diào)整數(shù)組的大?。?/p>

  1. var entries = [1, 2, 3, 4, 5, 6, 7];  
  2. console.log(entries.length);  
  3. // 7  
  4. entries.length = 4;  
  5. console.log(entries.length);  
  6. // 4  
  7. console.log(entries);  
  8. // [1, 2, 3, 4] 

如果我們要清空數(shù)組:

  1. var entries = [1, 2, 3, 4, 5, 6, 7];  
  2. console.log(entries.length);  
  3. // 7  
  4. entries.length = 0;  
  5. console.log(entries.length);  
  6. // 0  
  7. console.log(entries);  
  8. // [] 

你也在搜尋 JavaScript hacker 技巧的話,希望本文對(duì)你有幫助。

 

責(zé)任編輯:趙寧寧 來源: 前端工匠
相關(guān)推薦

2019-12-20 14:32:55

JavaScript函數(shù)開發(fā)

2020-09-29 08:14:46

JavaScript開發(fā)代碼

2020-12-14 08:30:02

JavaScript開發(fā)代碼

2023-03-19 16:02:33

JavaScrip技巧編程語言

2019-07-31 10:24:16

JavaScript瀏覽器口袋妖怪

2023-08-11 13:25:00

JavaScript

2011-04-07 16:46:09

Solaris

2020-05-09 17:05:50

Python字符串代碼

2012-01-06 09:09:56

JavaScript

2022-12-22 14:44:06

JavaScript技巧

2022-12-25 16:03:31

JavaScript技巧

2023-08-11 17:39:43

JavaScriptWeb 應(yīng)用程序

2023-11-26 17:54:07

JavaScript開發(fā)

2024-08-21 14:55:02

2019-07-24 15:29:55

JavaScript開發(fā) 技巧

2020-06-09 10:24:58

JavaScript開發(fā)技術(shù)

2012-04-13 09:45:53

JavaScriptjQuery

2021-02-20 23:34:22

JavaScript運(yùn)算符開發(fā)

2020-12-07 08:01:59

JavaScript入門技巧

2023-07-18 07:56:31

工具reduce業(yè)務(wù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)