摘要:否則,將返回空數組的長度。該提案目前處于第階段,作為一項實驗性功能。轉換為布爾值除了常規的布爾值和之外,還將所有其他值視為或。這也可以用于將布爾值轉換為數字,如下所示在某些上下文中,將被解釋為連接操作符,而不是加法操作符。
譯者:前端小智
原文:medium.com/@bretcamero…
當我開始學習JavaScript時,我把我在別人的代碼、code challenge網站以及我使用的教程之外的任何地方發現的每一個節省時間的技巧都列了一個清單。
在這篇文章中,我將分享11條我認為特別有用的技巧。這篇文章是為初學者準備的,但我希望即使是中級JavaScript開發人員也能在這個列表中找到一些新的東西。
想閱讀更多優質文章請猛戳GitHub博客,一年百來篇優質文章等著你!
1..過濾唯一值Set對象類型是在ES6中引入的,配合展開操作...一起,我們可以使用它來創建一個新數組,該數組只有唯一的值。
const array = [1, 1, 2, 3, 5, 5, 1] const uniqueArray = [...new Set(array)]; console.log(uniqueArray); // Result: [1, 2, 3, 5]
在ES6之前,隔離惟一值將涉及比這多得多的代碼。
此技巧適用于包含基本類型的數組:undefined,null,boolean,string和number。 (如果你有一個包含對象,函數或其他數組的數組,你需要一個不同的方法!)
##2. 與或運算
三元運算符是編寫簡單(有時不那么簡單)條件語句的快速方法,如下所示:
x > 100 ");
但有時使用三元運算符處理也會很復雜。 相反,我們可以使用"與"&&和"或"|| 邏輯運算符以更簡潔的方式書寫表達式。 這通常被稱為“短路”或“短路運算”。
假設我們只想返回兩個或多個選項中的一個。
使用&&將返回第一個條件為假的值。如果每個操作數的計算值都為true,則返回最后一個計算過的表達式。
let one = 1, two = 2, three = 3; console.log(one && two && three); // Result: 3 console.log(0 && null); // Result: 0
使用||將返回第一個條件為真的值。如果每個操作數的計算結果都為false,則返回最后一個計算過的表達式。
let one = 1, two = 2, three = 3; console.log(one || two || three); // Result: 1 console.log(0 || null); // Result: null
假設我們想返回一個變量的長度,但是我們不知道變量的類型。
我們可以使用if/else語句來檢查foo是可接受的類型,但是這可能會變得非常冗長?;蜻\行可以幫助我們簡化操作:
return (foo || []).length
如果變量foo是true,它將被返回。否則,將返回空數組的長度:0。
你是否遇到過訪問嵌套對象屬性的問題? 你可能不知道對象或其中一個子屬性是否存在,這可能會導致令人沮喪的錯誤。
假設我們想在this.state中訪問一個名為data的屬性,但是在我們的程序成功返回一個獲取請求之前,data 是未定義的。
根據我們使用它的位置,調用this.state.data可能會阻止我們的應用程序運行。 為了解決這個問題,我們可以將其做進一步的判斷:
if (this.state.data) { return this.state.data; } else { return "Fetching Data"; }
但這似乎很重復。 "或" 運算符提供了更簡潔的解決方案:
return (this.state.data || "Fetching Data");
過去在 Object 屬性鏈的調用中,很容易因為某個屬性不存在而導致之后出現Cannot read property xxx of undefined的錯誤。
那 optional chaining 就是添加了");這么個操作符,它會先判斷前面的值,如果是 null 或 undefined,就結束調用、返回 undefined。
例如,我們可以將上面的示例重構為 this.state.data");?;蛘撸绻覀冎饕P注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”。
const isTrue = !0; const isFalse = !1; const alsoFalse = !!0; console.log(isTrue); // Result: true console.log(typeof true); // Result: "boolean"4. 轉換為字符串
要快速地將數字轉換為字符串,我們可以使用連接運算符+后跟一組空引號""。
const val = 1 + ""; console.log(val); // Result: "1" console.log(typeof val); // Result: "string"5. 轉換為數字
使用加法運算符+可以快速實現相反的效果。
let int = "15"; int = +int; console.log(int); // Result: 15 console.log(typeof int); Result: "number"
這也可以用于將布爾值轉換為數字,如下所示
console.log(+true); // Return: 1 console.log(+false); // Return: 0
在某些上下文中,+將被解釋為連接操作符,而不是加法操作符。當這種情況發生時(你希望返回一個整數,而不是浮點數),您可以使用兩個波浪號:~~。
連續使用兩個波浪有效地否定了操作,因為—?(?—?n?—?1)?—?1 = n + 1?—?1 = n。 換句話說,~—16 等于15。
const int = ~~"15" console.log(int); // Result: 15 console.log(typeof int); Result: "number"
雖然我想不出很多用例,但是按位NOT運算符也可以用在布爾值上:~true = -2和~false = -1。
6.性能更好的運算從ES7開始,可以使用指數運算符**作為冪的簡寫,這比編寫Math.pow(2, 3) 更快。 這是很簡單的東西,但它之所以出現在列表中,是因為沒有多少教程更新過這個操作符。
console.log(2 ** 3); // Result: 8
這不應該與通常用于表示指數的^符號相混淆,但在JavaScript中它是按位異或運算符。
在ES7之前,只有以2為基數的冪才存在簡寫,使用按位左移操作符<<
Math.pow(2, n); 2 << (n - 1); 2**n;
例如,2 << 3 = 16等于2 ** 4 = 16。
7. 快速浮點數轉整數如果希望將浮點數轉換為整數,可以使用Math.floor()、Math.ceil()或Math.round()。但是還有一種更快的方法可以使用|(位或運算符)將浮點數截斷為整數。
console.log(23.9 | 0); // Result: 23 console.log(-23.9 | 0); // Result: -23
|的行為取決于處理的是正數還是負數,所以最好只在確定的情況下使用這個快捷方式。
如果n為正,則n | 0有效地向下舍入。 如果n為負數,則有效地向上舍入。 更準確地說,此操作將刪除小數點后面的任何內容,將浮點數截斷為整數。
你可以使用~~來獲得相同的舍入效果,如上所述,實際上任何位操作符都會強制浮點數為整數。這些特殊操作之所以有效,是因為一旦強制為整數,值就保持不變。
按位或運算符還可以用于從整數的末尾刪除任意數量的數字。這意味著我們不需要使用這樣的代碼來在類型之間進行轉換。
let str = "1553"; Number(str.substring(0, str.length - 1));
相反,按位或運算符可以這樣寫:
console.log(1553 / 10 | 0) // Result: 155 console.log(1553 / 100 | 0) // Result: 15 console.log(1553 / 1000 | 0) // Result: 18. 類中的自動綁定
我們可以在類方法中使用ES6箭頭表示法,并且通過這樣做可以隱含綁定。 這通常會在我們的類構造函數中保存幾行代碼,我們可以愉快地告別重復的表達式,例如this.myMethod = this.myMethod.bind(this)
import React, { Component } from React; export default class App extends Compononent { constructor(props) { super(props); this.state = {}; } myMethod = () => { // This method is bound implicitly! } render() { return ( <>9. 數組截斷{this.myMethod()}> ) } };
如果要從數組的末尾刪除值,有比使用splice()更快的方法。
例如,如果你知道原始數組的大小,您可以重新定義它的length屬性,就像這樣
let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; array.length = 4; console.log(array); // Result: [0, 1, 2, 3]
這是一個特別簡潔的解決方案。但是,我發現slice()方法的運行時更快。如果速度是你的主要目標,考慮使用:
let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; array = array.slice(0, 4); console.log(array); // Result: [0, 1, 2, 3]10. 獲取數組中的最后一項
數組方法slice()可以接受負整數,如果提供它,它將接受數組末尾的值,而不是數組開頭的值。
let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; console.log(array.slice(-1)); // Result: [9] console.log(array.slice(-2)); // Result: [8, 9] console.log(array.slice(-3)); // Result: [7, 8, 9]11.格式化JSON代碼
最后,你之前可能已經使用過JSON.stringify,但是您是否意識到它還可以幫助你縮進JSON?
stringify()方法有兩個可選參數:一個replacer函數,可用于過濾顯示的JSON和一個空格值。
console.log(JSON.stringify({ alpha: "A", beta: "B" }, null, " ")); // Result: // "{ // "alpha": A, // "beta": B // }"
你的點贊是我持續分享好東西的動力,歡迎點贊!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/7863.html
摘要:否則,將返回空數組的長度。該提案目前處于第階段,作為一項實驗性功能。轉換為布爾值除了常規的布爾值和之外,還將所有其他值視為或。這也可以用于將布爾值轉換為數字,如下所示在某些上下文中,將被解釋為連接操作符,而不是加法操作符。 當我開始學習JavaScript時,我把我在別人的代碼、code challenge網站以及我使用的教程之外的任何地方發現的每一個節省時間的技巧都列了一個清單。 在...
摘要:否則,將返回空數組的長度。該提案目前處于第階段,作為一項實驗性功能。轉換為布爾值除了常規的布爾值和之外,還將所有其他值視為或。這也可以用于將布爾值轉換為數字,如下所示在某些上下文中,將被解釋為連接操作符,而不是加法操作符。 當我開始學習JavaScript時,我把我在別人的代碼、code challenge網站以及我使用的教程之外的任何地方發現的每一個節省時間的技巧都列了一個清單。 在...
摘要:對進行序列化和反序列化避免使用和構造函數使用和構造函數是非常昂貴的操作,因為每次他們都會調用腳本引擎將源代碼轉換成可執行代碼。 原文:45 Useful JavaScript Tips, Tricks and Best Practices 譯文:45個有用的JavaScript技巧,竅門和最佳實踐 譯者:dwqs 在這篇文章中,我將分享一些JavaScript常用的技巧,竅門和最...
摘要:函數式編程前端掘金引言面向對象編程一直以來都是中的主導范式。函數式編程是一種強調減少對程序外部狀態產生改變的方式。 JavaScript 函數式編程 - 前端 - 掘金引言 面向對象編程一直以來都是JavaScript中的主導范式。JavaScript作為一門多范式編程語言,然而,近幾年,函數式編程越來越多得受到開發者的青睞。函數式編程是一種強調減少對程序外部狀態產生改變的方式。因此,...
摘要:官網地址聊天機器人插件開發實例教程一創建插件在系統技巧使你的更加專業前端掘金一個幫你提升技巧的收藏集。我會簡單基于的簡潔視頻播放器組件前端掘金使用和實現購物車場景前端掘金本文是上篇文章的序章,一直想有機會再次實踐下。 2道面試題:輸入URL按回車&HTTP2 - 掘金通過幾輪面試,我發現真正那種問答的技術面,寫一堆項目真不如去刷技術文章作用大,因此刷了一段時間的博客和掘金,整理下曾經被...
閱讀 3648·2021-10-09 09:58
閱讀 1188·2021-09-22 15:20
閱讀 2495·2019-08-30 15:54
閱讀 3510·2019-08-30 14:08
閱讀 887·2019-08-30 13:06
閱讀 1817·2019-08-26 12:16
閱讀 2678·2019-08-26 12:11
閱讀 2507·2019-08-26 10:38