成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

11 種在大多數教程中找不到的JavaScript技巧

開發 前端
Set對象類型是在ES6中引入的,配合展開操作...一起,我們可以使用它來創建一個新數組,該數組只有唯一的值。

[[284372]]

 1..過濾唯一值

Set對象類型是在ES6中引入的,配合展開操作...一起,我們可以使用它來創建一個新數組,該數組只有唯一的值。

 

11 種在大多數教程中找不到的JavaScript技巧

 

在ES6之前,隔離惟一值將涉及比這多得多的代碼。

此技巧適用于包含基本類型的數組:undefined,null,boolean,string和number。 (如果你有一個包含對象,函數或其他數組的數組,你需要一個不同的方法!)

2. 與或運算

三元運算符是編寫簡單(有時不那么簡單)條件語句的快速方法,如下所示:

 

11 種在大多數教程中找不到的JavaScript技巧

 

但有時使用三元運算符處理也會很復雜。 相反,我們可以使用'與'&&和'或'|| 邏輯運算符以更簡潔的方式書寫表達式。 這通常被稱為“短路”或“短路運算”。

它是怎么工作的

假設我們只想返回兩個或多個選項中的一個。

使用&&將返回第一個條件為假的值。如果每個操作數的計算值都為true,則返回最后一個計算過的表達式。

 

11 種在大多數教程中找不到的JavaScript技巧

 

使用||將返回第一個條件為真的值。如果每個操作數的計算結果都為false,則返回最后一個計算過的表達式。

 

11 種在大多數教程中找不到的JavaScript技巧

 

例一

假設我們想返回一個變量的長度,但是我們不知道變量的類型。

我們可以使用if/else語句來檢查foo是可接受的類型,但是這可能會變得非常冗長。或運行可以幫助我們簡化操作:

 

  1. return (foo || []).length 

如果變量foo是true,它將被返回。否則,將返回空數組的長度:0。

例二

你是否遇到過訪問嵌套對象屬性的問題? 你可能不知道對象或其中一個子屬性是否存在,這可能會導致令人沮喪的錯誤。

假設我們想在this.state中訪問一個名為data的屬性,但是在我們的程序成功返回一個獲取請求之前,data 是未定義的。

根據我們使用它的位置,調用this.state.data可能會阻止我們的應用程序運行。 為了解決這個問題,我們可以將其做進一步的判斷:

 

  1. if (this.state.data) { 
  2.  return this.state.data; 
  3. else { 
  4.  return 'Fetching Data'

但這似乎很重復。 '或' 運算符提供了更簡潔的解決方案:

 

  1. return (this.state.data || 'Fetching Data'); 

一個新特性: Optional Chaining

過去在 Object 屬性鏈的調用中,很容易因為某個屬性不存在而導致之后出現Cannot read property xxx of undefined的錯誤。

那 optional chaining 就是添加了?.這么個操作符,它會先判斷前面的值,如果是 null 或 undefined,就結束調用、返回 undefined。

例如,我們可以將上面的示例重構為 this.state.data?.()。或者,如果我們主要關注state 是否已定義,我們可以返回this.state?.data。

該提案目前處于第1階段,作為一項實驗性功能。 你可以在這里閱讀它,你現在可以通過Babel使用你的JavaScript,將 @babel/plugin-proposal-optional-chaining添加到你的.babelrc文件中。

3.轉換為布爾值

除了常規的布爾值true和false之外,JavaScript還將所有其他值視為 ‘truthy’或‘falsy’。

除非另有定義,否則 JavaScript 中的所有值都是'truthy',除了 0,“”,null,undefined,NaN,當然還有false,這些都是'falsy'

我們可以通過使用負算運算符輕松地在true和false之間切換。它也會將類型轉換為“boolean”。

 

11 種在大多數教程中找不到的JavaScript技巧

 

4. 轉換為字符串

要快速地將數字轉換為字符串,我們可以使用連接運算符+后跟一組空引號""。

 

11 種在大多數教程中找不到的JavaScript技巧

 

5. 轉換為數字

使用加法運算符+可以快速實現相反的效果。

 

11 種在大多數教程中找不到的JavaScript技巧

 

這也可以用于將布爾值轉換為數字,如下所示

 

  1. console.log(+true); // Return: 1 
  2. console.log(+false); // Return: 0 

在某些上下文中,+將被解釋為連接操作符,而不是加法操作符。當這種情況發生時(你希望返回一個整數,而不是浮點數),您可以使用兩個波浪號:~~。

連續使用兩個波浪有效地否定了操作,因為— ( — n — 1) — 1 = n + 1 — 1 = n。 換句話說,~—16 等于15。

 

  1. const int = ~~"15" 
  2. console.log(int); // Result: 15 
  3. console.log(typeof int); Result: "number" 

雖然我想不出很多用例,但是按位NOT運算符也可以用在布爾值上:~true = -2和~false = -1。

6.性能更好的運算

從ES7開始,可以使用指數運算符**作為冪的簡寫,這比編寫Math.pow(2, 3) 更快。 這是很簡單的東西,但它之所以出現在列表中,是因為沒有多少教程更新過這個操作符。

 

  1. console.log(2 ** 3); // Result: 8 

這不應該與通常用于表示指數的^符號相混淆,但在JavaScript中它是按位異或運算符。

在ES7之前,只有以2為基數的冪才存在簡寫,使用按位左移操作符<<

 

  1. Math.pow(2, n); 
  2. 2 << (n - 1); 
  3. 2**n; 

例如,2 << 3 = 16等于2 ** 4 = 16。

7. 快速浮點數轉整數

如果希望將浮點數轉換為整數,可以使用Math.floor()、Math.ceil()或Math.round()。但是還有一種更快的方法可以使用|(位或運算符)將浮點數截斷為整數。

 

  1. console.log(23.9 | 0); // Result: 23 
  2. console.log(-23.9 | 0); // Result: -23 

|的行為取決于處理的是正數還是負數,所以最好只在確定的情況下使用這個快捷方式。

如果n為正,則n | 0有效地向下舍入。 如果n為負數,則有效地向上舍入。 更準確地說,此操作將刪除小數點后面的任何內容,將浮點數截斷為整數。

你可以使用~~來獲得相同的舍入效果,如上所述,實際上任何位操作符都會強制浮點數為整數。這些特殊操作之所以有效,是因為一旦強制為整數,值就保持不變。

刪除最后一個數字

按位或運算符還可以用于從整數的末尾刪除任意數量的數字。這意味著我們不需要使用這樣的代碼來在類型之間進行轉換。

 

  1. let str = "1553";  
  2. Number(str.substring(0, str.length - 1)); 

相反,按位或運算符可以這樣寫:

 

  1. console.log(1553 / 10 | 0) // Result: 155 
  2. console.log(1553 / 100 | 0) // Result: 15 
  3. console.log(1553 / 1000 | 0) // Result: 1 

8. 類中的自動綁定

我們可以在類方法中使用ES6箭頭表示法,并且通過這樣做可以隱含綁定。 這通常會在我們的類構造函數中保存幾行代碼,我們可以愉快地告別重復的表達式,例如this.myMethod = this.myMethod.bind(this)

 

11 種在大多數教程中找不到的JavaScript技巧

 

9. 數組截斷

如果要從數組的末尾刪除值,有比使用splice()更快的方法。

例如,如果你知道原始數組的大小,您可以重新定義它的length屬性,就像這樣

 

  1. let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; 
  2. array.length = 4; 
  3. console.log(array); // Result: [0, 1, 2, 3] 

這是一個特別簡潔的解決方案。但是,我發現slice()方法的運行時更快。如果速度是你的主要目標,考慮使用:

 

  1. let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; 
  2. array = array.slice(0, 4); 
  3. console.log(array); // Result: [0, 1, 2, 3] 

10. 獲取數組中的最后一項

數組方法slice()可以接受負整數,如果提供它,它將接受數組末尾的值,而不是數組開頭的值。

 

  1. let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; 
  2. console.log(array.slice(-1)); // Result: [9] 
  3. console.log(array.slice(-2)); // Result: [8, 9] 
  4. console.log(array.slice(-3)); // Result: [7, 8, 9] 

11.格式化JSON代碼

最后,你之前可能已經使用過JSON.stringify,但是您是否意識到它還可以幫助你縮進JSON?

stringify()方法有兩個可選參數:一個replacer函數,可用于過濾顯示的JSON和一個空格值。

 

  1. console.log(JSON.stringify({ alpha: 'A', beta: 'B' }, null'\t')); 
  2. // Result: 
  3. // '{ 
  4. // "alpha": A, 
  5. // "beta": B 
  6. // }' 

 

責任編輯:華軒 來源: 今日頭條
相關推薦

2016-10-26 09:42:13

2016-11-13 19:51:16

2009-07-14 15:39:34

Swing大多數控件

2011-05-26 10:50:31

2014-01-02 10:34:54

設計設計師

2024-07-04 15:47:28

2021-09-17 16:00:33

Windows 11微軟虛擬機

2020-07-05 08:01:44

SOC威脅檢測漏洞

2019-12-13 17:29:50

物聯網大數據安全

2020-08-25 19:18:23

自動駕駛人工智能AI

2025-03-20 13:25:36

2012-12-19 10:07:18

2023-10-13 10:36:09

物聯網智能建筑

2024-08-20 15:23:27

JavaScript開發

2013-03-28 10:01:50

云計算

2023-05-28 23:23:44

2022-06-10 10:19:15

路由器漏洞

2023-02-27 15:44:17

Java開發技巧

2021-01-18 15:28:13

加密貨幣比特幣貨幣

2010-05-07 13:59:53

谷歌云計算
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产中文| 无码一区二区三区视频 | 久在线观看 | 伊人伊成久久人综合网站 | 亚洲综合大片69999 | 四虎在线视频 | 有码一区| 在线成人一区 | 黄网站免费在线观看 | 日韩欧美福利视频 | 日日摸夜夜添夜夜添特色大片 | 羞羞的视频免费观看 | 日韩精品999 | 国户精品久久久久久久久久久不卡 | 久久伊人免费视频 | 久久久久免费精品国产小说色大师 | 成人午夜高清 | 北条麻妃99精品青青久久主播 | 美国黄色一级片 | 在线中文视频 | 精品欧美一区二区三区久久久 | 欧美无乱码久久久免费午夜一区 | 亚洲一区二区三区在线免费 | 久久99精品久久久久久国产越南 | 一区二区在线看 | 嫩草91在线| 91免费在线视频 | 欧美激情一区 | 国产精品久久久久aaaa九色 | 日韩高清一区 | 成年女人免费v片 | 中文字幕日本一区二区 | 欧美美女爱爱视频 | 国产成人jvid在线播放 | 中文字幕视频三区 | 国产91久久久久蜜臀青青天草二 | 黄色在线免费观看视频网站 | 亚洲一区二区在线播放 | 久久精品视频播放 | 亚洲欧美综合 | 国产精品视屏 |