国产精品爱久久久久久久小说,女人扒开腿让男人桶到爽 ,亚洲欧美国产双大乳头,国产成人精品综合久久久久,国产精品制服丝袜无码,免费无码精品黄av电影,黑色丝袜无码中中文字幕,乱熟女高潮一区二区在线

    10 個超有用的 JavaScript 技巧

    2020-5-6    seo達(dá)人

    方法參數(shù)的驗證

    JavaScript 允許你設(shè)置參數(shù)的默認(rèn)值。通過這種方法,可以通過一個巧妙的技巧來驗證你的方法參數(shù)。


    const isRequired = () => { throw new Error('param is required'); };

    const print = (num = isRequired()) => { console.log(`printing ${num}`) };

    print(2);//printing 2

    print()// error

    print(null)//printing null

    非常整潔,不是嗎?


    格式化 json 代碼

    你可能對 JSON.stringify 非常熟悉。但是你是否知道可以用 stringify 進(jìn)行格式化輸出?實際上這很簡單。


    stringify 方法需要三個輸入。 value,replacer 和 space。后兩個是可選參數(shù)。這就是為什么我們以前沒有注意過它們。要對 json 進(jìn)行縮進(jìn),必須使用 space 參數(shù)。


    console.log(JSON.stringify({name:"John",Age:23},null,'\t'));

    >>>

    {

    "name": "John",

    "Age": 23

    }

    從數(shù)組中獲取唯一值

    要從數(shù)組中獲取唯一值,我們需要使用 filter 方法來過濾出重復(fù)值。但是有了新的 Set 對象,事情就變得非常順利和容易了。


    let uniqueArray = [...new Set([1, 2, 3, 3, 3, "school", "school", 'ball', false, false, true, true])];

    >>> [1, 2, 3, "school", "ball", false, true]

    從數(shù)組中刪除虛值(Falsy Value)

    在某些情況下,你可能想從數(shù)組中刪除虛值。虛值是 JavaScript 的 Boolean 上下文中被認(rèn)定為為 false 的值。 JavaScript 中只有六個虛值,它們是:


    undefined

    null

    NaN

    0

    "" (空字符串)

    false

    濾除這些虛值的最簡單方法是使用以下函數(shù)。


    myArray.filter(Boolean);

    如果要對數(shù)組進(jìn)行一些修改,然后過濾新數(shù)組,可以嘗試這樣的操作。請記住,原始的 myArray 會保持不變。


    myArray

       .map(item => {

           // Do your changes and return the new item

       })

       .filter(Boolean);

    合并多個對象

    假設(shè)我有幾個需要合并的對象,那么這是我的首選方法。


    const user = {

        name: 'John Ludwig',

        gender: 'Male'

    };

    const college = {

        primary: 'Mani Primary School',

        secondary: 'Lass Secondary School'

    };

    const skills = {

       programming: 'Extreme',

       swimming: 'Average',

       sleeping: 'Pro'

    };

    const summary = {...user, ...college, ...skills};

    這三個點在 JavaScript 中也稱為展開運算符。你可以在這里學(xué)習(xí)更多用法。


    對數(shù)字?jǐn)?shù)組進(jìn)行排序

    JavaScript 數(shù)組有內(nèi)置的 sort 方法。默認(rèn)情況下 sort 方法把數(shù)組元素轉(zhuǎn)換為字符串,并對其進(jìn)行字典排序。在對數(shù)字?jǐn)?shù)組進(jìn)行排序時,這有可能會導(dǎo)致一些問題。所以下面是解決這類問題的簡單解決方案。


    [0,10,4,9,123,54,1].sort((a,b) => a-b);

    >>> [0, 1, 4, 9, 10, 54, 123]

    這里提供了一個將數(shù)字?jǐn)?shù)組中的兩個元素與 sort 方法進(jìn)行比較的函數(shù)。這個函數(shù)可幫助我們接收正確的輸出。


    Disable Right Click

    禁用右鍵

    你可能想要阻止用戶在你的網(wǎng)頁上單擊鼠標(biāo)右鍵。


    <body oncontextmenu="return false">

       <div></div>

    </body>

    這段簡單的代碼將為你的用戶禁用右鍵單擊。


    使用別名進(jìn)行解構(gòu)

    解構(gòu)賦值語法是一種 JavaScript 表達(dá)式,可以將數(shù)組中的值或?qū)ο蟮闹祷驅(qū)傩苑峙浣o變量。解構(gòu)賦值能讓我們用更簡短的語法進(jìn)行多個變量的賦值。


    const object = { number: 10 };


    // Grabbing number

    const { number } = object;


    // Grabbing number and renaming it as otherNumber

    const { number: otherNumber } = object;

    console.log(otherNumber); //10

    獲取數(shù)組中的最后一項

    可以通過對 splice 方法的參數(shù)傳入負(fù)整數(shù),來數(shù)獲取組末尾的元素。


    let array = [0, 1, 2, 3, 4, 5, 6, 7]

    console.log(array.slice(-1));

    >>>[7]

    console.log(array.slice(-2));

    >>>[6, 7]

    console.log(array.slice(-3));

    >>>[5, 6, 7]

    等待 Promise 完成

    在某些情況下,你可能會需要等待多個 promise 結(jié)束。可以用 Promise.all 來并行運行我們的 promise。


    const PromiseArray = [

       Promise.resolve(100),

       Promise.reject(null),

       Promise.resolve("Data release"),

       Promise.reject(new Error('Something went wrong'))];


    Promise.all(PromiseArray)

     .then(data => console.log('all resolved! here are the resolve values:', data))

     .catch(err => console.log('got rejected! reason:', err))

    關(guān)于 Promise.all 的主要注意事項是,當(dāng)一個 Promise 拒絕時,該方法將引發(fā)錯誤。這意味著你的代碼不會等到你所有的 promise 都完成。


    如果你想等到所有 promise 都完成后,無論它們被拒絕還是被解決,都可以使用 Promise.allSettled。此方法在 ES2020 的最終版本得到支持。


    const PromiseArray = [

       Promise.resolve(100),

       Promise.reject(null),

       Promise.resolve("Data release"),

       Promise.reject(new Error('Something went wrong'))];


    Promise.allSettled(PromiseArray).then(res =>{

    console.log(res);

    }).catch(err => console.log(err));


    //[

    //{status: "fulfilled", value: 100},

    //{status: "rejected", reason: null},

    //{status: "fulfilled", value: "Data release"},

    //{status: "rejected", reason: Error: Something went wrong ...}

    //]

    即使某些 promise 被拒絕,Promise.allSettled 也會從你所有的 promise 中返回結(jié)果。

    日歷

    鏈接

    個人資料

    存檔

    主站蜘蛛池模板: 国产私拍大尺度在线视频| 欧美熟妇精品黑人巨大一二三区| 在线成人国产| 老妇肥熟凸凹丰满刺激| 国产三级国产经典国产av| 一亲二脱三插| 亚洲国产精品久久久久久| 久久久久免费看成人影片| 久久亚洲中文字幕伊人久久大 | 国产婷婷色一区二区三区在线| 欧美精品一区二区黄a片| 综合激情网站| 最近日韩免费视频| 一本到无码av专区无码不卡| 欧美aⅴ| 亚洲最大福利视频| 久久久这里只有精品10| 蜜臀久久99精品久久久久久小说| 日本大尺度床戏揉捏胸| av不卡一区二区| 国产熟人av一二三区| 青草久久久国产线免观| 日本成人不卡| 中文午夜人妻无码看片| 97人人插| 超碰资源总站| 777亚洲熟妇自拍无码区| 亚洲线精品一区二区三八戒| 国产成人a亚洲精品| 男人激情网| 国产精品怡红院永久免费| 国精品人妻无码一区二区三区d3| 台湾佬中文字幕| 青青草原伊人网| 色爱无码av综合区| 亚洲精品国偷拍自产在线观看| 亚洲伦理一区| 免费黄色成人| 性做久久久久久| 久久久这里只有免费精品| www久久久|