日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

10 個你可能還不知道的很酷JavaScript特性

 風聲之家 2021-11-13

WEB前端開發(fā)社區(qū)

 2021-11-13

您可能使用 JavaScript 很長時間了,它的最新版本是 ES12。您可能正在使用它的一些功能,今天,我想重點介紹其中的一些功能,它們可能有助于您編寫更好、更清晰、更優(yōu)的 JavaScript 代碼。
1、空運算符
如果左側為空或未定義,則此運算符返回右側值。
const data= null ?? 'data';console.log(data);// expected output: "data"const data1 = 1 ?? 4;console.log(data1);// expected output: 1
邏輯 OR (||) 運算符執(zhí)行相同的操作,但是,當將 0 作為值傳遞時,它將視為 false,這使得它容易用于數(shù)字。
function add(a, b) {    val1 = a || 1;    val2 = b || 1;    sum = val1 + val2;    return sum;}
console.log(add(0, 0)); //output:2
當我們使用 Nullish 運算符時,同樣的事情
function add1(a, b) {    val1 = a ?? 1;    val2 = b ?? 1;    sum = val1 + val2;    return sum;}
console.log(add1(0, 0)); //ouput:0
2、Switch 語句優(yōu)化
如果你想優(yōu)化你的 switch 語句,那么,這個語句會有所幫助。
// Longhandswitch (data) {    case 1:        data1();        break;    case 2:        data2();        break;    case 3:        data();        break;        // And so on...}// Shorthandvar data = {    1: data1,    2: data2,    3: data};const val = 1data[val]();function data1() {    console.log("data1");}function data2() {    console.log("data2");}function data() {    console.log("data");}
3、控制臺樣式
您是否厭倦了使用相同的控制臺?現(xiàn)在我們可以設計我們的控制臺。
console.log(`%cabc`, 'font-weight:bold;color:red');
4、AND (&&) 運算符
如果我們想避免一個 if 語句,那么這個速記會很有幫助。
//Longhand if (test1) { callMethod(); }//Shorthand test1 && callMethod();
5、短函數(shù)調(diào)用
我們可以使用三元運算符來實現(xiàn)這些功能。
// Longhandfunction data1() {    console.log('data1');};function data2() {    console.log('data2');};var data3 = 1;if (data3 == 1) {    data1();} else {    data2();} //data1// Shorthand(data3 === 1 ? data1 : data2)(); //data1
6、返回簡寫
這將有助于避免大量代碼專門返回到基于返回語句的調(diào)用方法。
// Longhandlet value;function returnMe() {    if (!(value === undefined)) {        return value;    } else {        return callFunction('value');    }}var data = returnMe();console.log(data); //output valuefunction callFunction(val) {    console.log(val);}// Shorthandfunction returnMe() {    return value || callFunction('value');}
7、 If... else 簡寫
當我們有 if-else 語句時,這會有所幫助(確保您有最多 2-3 個 if...else 語句,因為多于這些會降低代碼的可讀性)。
// Longhandlet mychoice: boolean;if (money > 100) {    mychoice= true;} else {    mychoice= false;}// Shorthandlet mychoice= (money > 10) ? true : false;//or we can use directlylet mychoice= money > 10;console.log(mychoice);
嵌套條件如下所示:
let salary = 300,checking = (salary > 100) ? 'greater 100' : (x < 50) ? 'less 50' : 'between 50 and 100';console.log(checking); // "greater than 100"
8、可選鏈
有時,訪問未定義的屬性會出錯,我們需要為所有嵌套對象屬性添加空檢查。可以使用可選鏈接來減少它。
const data = {    a: 1,    b: 'atit',    d: {        test1: {            test2: 'patel',        },    },};console.log(data.val.test1); // here val is not present in object which leads the errorError: Cannot read properties of undefined (reading 'test1')console.log(data?.val); // using this we can check if the val is present in the data or not
9、對象屬性賦值
當我們想從兩個字符串創(chuàng)建對象并保持與字符串相同的鍵時,可以使用這個技巧來完成。
let data1 = 'abcd'; let data2 = 'efgh';//Longhand let data = {data1: data1, data2: data2};//Shorthand let data = {data1, data2};
10、延遲
當 JavaScript 代碼量增加時,可能會導致瀏覽器必須等到所有腳本都執(zhí)行完后再加載 DOM,從而增加了等待時間。
通過使用這個屬性,我們可以告訴瀏覽器不要等待腳本;相反,它將繼續(xù)構建 DOM,并在后臺加載腳本。
<p>heading before loads</p><script defer src="src/test.js"></script><p>heading after loads</p>
總結
以上就是我今天與你分享的10個關于JavaScript 技巧的知識,希望能夠有助于您的代碼看起來更好,并幫助您在 JavaScript 中編寫更清晰的代碼。
英文 | https://javascript./5-cool-javascript-features-you-might-not-know-about-yet-f2fc818bdd31
翻譯 | 楊小愛

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多