<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        JavaScript實用代碼小技巧

        來源:懂視網 責編:小采 時間:2020-11-27 22:09:31
        文檔

        JavaScript實用代碼小技巧

        JavaScript實用代碼小技巧:在上次的 Chrome DevTools 你可能不知道的小技巧 文中,得到很多開發(fā)朋友的反饋確實不知道這些小技巧。今天,我們來聊一聊在 EcmaScript5/6+ 中的一些小技巧,歡迎評論區(qū)討論下更多技巧。 JSON.stringify 我們平時經常會用到JSON 對象,比如當我們
        推薦度:
        導讀JavaScript實用代碼小技巧:在上次的 Chrome DevTools 你可能不知道的小技巧 文中,得到很多開發(fā)朋友的反饋確實不知道這些小技巧。今天,我們來聊一聊在 EcmaScript5/6+ 中的一些小技巧,歡迎評論區(qū)討論下更多技巧。 JSON.stringify 我們平時經常會用到JSON 對象,比如當我們

        在上次的 “Chrome DevTools 你可能不知道的小技巧” 文中,得到很多開發(fā)朋友的反饋確實不知道這些小技巧。今天,我們來聊一聊在 EcmaScript5/6+ 中的一些小技巧,歡迎評論區(qū)討論下更多技巧。

        JSON.stringify

        我們平時經常會用到JSON 對象,比如當我們要實現(xiàn)對象的深拷貝時,我們可以用JSON 對象的JSON.stringify和JSON.parse 來拷貝一個完全一樣的對象,而不會對原對象產生任何引用關系。在使用localStorage 時,也會用到它,因為localStorage 只能存儲字符串格式的內容,所以,我們在存之前,將數(shù)值轉換成JSON字符串,取出來用的時候,再轉成對象或數(shù)組。

        對于JSON.stringify 方法,它可以幫我們把一個對象或數(shù)組轉換成一個JSON字符串。我們通常只會用到它的第一個參數(shù),其實它還有另外兩個參數(shù),可以讓它實現(xiàn)一些非常好用的功能。

        首先來看語法:

        JSON.stringify(value[, replacer [, space]])

        參數(shù):

      1. value:將要被序列化的變量的值
      2. replacer:替代器。可以是函數(shù)或者是數(shù)組,如果是一個函數(shù),則value 每個屬性都要經過這個函數(shù)的處理,該函數(shù)的返回值就是最后被序列化后的值。如果是一個數(shù)組,則要求該數(shù)組的元素是字符串,且這些元素會被當做value 的鍵(key)進行匹配,最后序列化的結果,是只包含該數(shù)組每個元素為key 的值。
      3. space:指定輸出數(shù)值的代碼縮進,美化格式之用,可以是數(shù)字或者字符串。如果是數(shù)字(最大為10)的話,代表每行代碼的縮進是多少個空格。如果是字符串的話,該字符串(最多前十個字符)將作顯示在每行代碼之前。
      4. 這時候,你應該知道了。我們可以用JSON.stringify 來做序列化時的過濾,相當于我們可以自定義JSON.stringify 的解析邏輯。

        使用函數(shù)過濾并序列化對象:

        // 使用“函數(shù)”當替代器
        function replacer(key, value) {
         if (typeof value === "string") {
         return undefined;
         }
         return value;
        }
        var foo = {
         foundation: "Mozilla", 
         model: "box", 
         week: 45, 
         transport: "car", 
         month: 7
        };
        var jsonString = JSON.stringify(foo, replacer);
        // {"week":45,"month":7}

        使用數(shù)組過濾并序列化對象:

        // 使用“數(shù)組”當替代器
        const user = {
         name: 'zollero',
         nick: 'z',
         skills: ['JavaScript', 'CSS', 'HTML5']
        };
        JSON.stringify(user, ['name', 'skills'], 2);
        // "{
        // "name": "zollero",
        // "skills": [
        // "JavaScript",
        // "CSS",
        // "HTML5"
        // ]
        // }"

        還有一個有意思的東西,是對象的toJSON 屬性。

        如果一個對象有toJSON 屬性,當它被序列化的時候,不會對該對象進行序列化,而是將它的toJSON 方法的返回值進行序列化。

        見下面的例子:

        var obj = {
         foo: 'foo',
         toJSON: function () {
         return 'bar';
         }
        };
        JSON.stringify(obj); // '"bar"'
        JSON.stringify({x: obj}); // '{"x":"bar"}'

        用 Set 來實現(xiàn)數(shù)組去重

        在ES6 中,引入了一個新的數(shù)據(jù)結構類型:Set。而Set 與Array 的結構是很類似的,且Set 和Array 可以相互進行轉換。

        數(shù)組去重,也算是一個比較常見的前端面試題了,方法有很多種,這里不多贅述。下面我們看看用Set 和...(拓展運算符)可以很簡單的進行數(shù)組去重。

        const removeDuplicateItems = arr => [...new Set(arr)];
        removeDuplicateItems([42, 'foo', 42, 'foo', true, true]);
        //=> [42, "foo", true]

        用塊級作用域避免命名沖突

        在開發(fā)的過程中,通常會遇到命名沖突的問題,就是需要根據(jù)場景不同來定義不同的值來賦值給同一個變量。下面介紹一個使用ES6 中的塊級作用域 來解決這個問題的方法。

        比如,在使用switchcase 時,我們可以這樣做:

        switch (record.type) {
         case 'added': {
         const li = document.createElement('li');
         li.textContent = record.name;
         li.id = record.id;
         fragment.appendChild(li);
         break;
         }
         case 'modified': {
         const li = document.getElementById(record.id);
         li.textContent = record.name;
         break;
         }
        }

        函數(shù)參數(shù)值校驗

        我們知道,在ES6 中,為函數(shù)增加了參數(shù)默認值的特性,可以為參數(shù)設定一些默認值,可以讓代碼更簡潔,可維護。

        其實,我們可以通過這個特性來做函數(shù)參數(shù)值的校驗。

        首先,函數(shù)的參數(shù)可以是任意類型的值,也可以是函數(shù),比如下面這個:

        function fix(a = getA()) {
         console.log('a', a)
        }
        function getA() {
         console.log('get a')
         return 2
        }
        fix(1);
        // a 1
        fix();
        // get a
        // a 2

        可以看出,如果在調用fix 時傳了參數(shù)a ,則不會執(zhí)行函數(shù)getA,只有當不傳遞參數(shù)a 時,才會執(zhí)行函數(shù)getA。

        這時候,我們可以利用這一特性,為參數(shù)a 添加一個必傳的校驗,代碼如下:

        function fix(a = require()) {
         console.log('a', a)
        }
        function require() {
         throw new Error('缺少了參數(shù) a')
        }
        fix(1);
        // a 1
        fix();
        // Uncaught Error: 缺少了參數(shù) a

        用解構賦值過濾對象屬性

        在前面我們介紹了使用JSON.stringify 來過濾對象的屬性的方法。這里,我們介紹另外一種使用ES6 中的解構賦值 和拓展運算符 的特性來過濾屬性的方法。

        比如,下面這段示例:

        // 我們想過濾掉對象 types 中的 inner 和 outer 屬性
        const { inner, outer, ...restProps } = {
         inner: 'This is inner',
         outer: 'This is outer',
         v1: '1',
         v2: '2',
         v4: '3'
        };
        console.log(restProps);
        // {v1: "1", v2: "2", v4: "3"}

        用解構賦值獲取嵌套對象的屬性

        解構賦值 的特性很強大,它可以幫我們從一堆嵌套很深的對象屬性中,很方便地拿到我們想要的那一個。比如下面這段代碼:

        // 通過解構賦值獲取嵌套對象的值
        const car = {
         model: 'bmw 2018',
         engine: {
         v6: true,
         turbo: true,
         vin: 12345
         }
        };
        // 這里使用 ES6 中的簡單寫法,使用 { vin } 替代 { vin: vin }
        const modalAndVIN = ({ model, engine: { vin }}) => {
         console.log(`model: ${model}, vin: ${vin}`);
        }
        modalAndVIN(car);
        // "model: bmw 2018, vin: 12345"

        合并對象

        ES6 中新增的拓展運算符,可以用來解構數(shù)組,也可以用來解構對象,它可以將對象中的所有屬性展開。

        通過這個特性,我們可以做一些對象合并的操作,如下:

        // 使用拓展運算符合并對象,在后面的屬性會重寫前面相同屬性的值
        const obj1 = { a: 1, b: 2, c: 3 };
        const obj2 = { c: 5, d: 9 };
        const merged = { ...obj1, ...obj2 };
        console.log(merged);
        // {a: 1, b: 2, c: 5, d: 9}
        const obj3 = { a: 1, b: 2 };
        const obj4 = { c: 3, d: { e: 4, ...obj3 } };
        console.log(obj4);
        // {c: 3, d: {a: 1, b: 2, e: 4} }

        使用 === 代替 ==

        在JavaScript 中,=== 和== 是有很大的不同的,== 會將兩邊的變量進行轉義,然后將轉義后的值進行比較,而=== 是嚴格比較,要求兩邊的變量不僅值要相同,它們自身的類型也要相同。

        JavaScript 經常被調侃成一個神奇的語言,就是因為它的轉義的特性,而用== 可能會引入一些深埋的bug。遠離 bug,還是要用===:

        [10] == 10 // true
        [10] === 10 // false
        '10' == 10 // true
        '10' === 10 // false
         [] == 0 // true
         [] === 0 // false
         '' == false // true
         '' === false // false

        當然,在用=== 時,也會出問題,比如:

        NaN === NaN // false

        ES6 中提供了一個新的方法:Object.is(),它具有=== 的一些特點,而且更好、更準確,在一些特殊場景下變現(xiàn)的更好:

        Object.is(0 , ' '); //false
        Object.is(null, undefined); //false
        Object.is([1], true); //false
        Object.is(NaN, NaN); //true

        下圖,是關于==、=== 和Object.is 的對比:

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        JavaScript實用代碼小技巧

        JavaScript實用代碼小技巧:在上次的 Chrome DevTools 你可能不知道的小技巧 文中,得到很多開發(fā)朋友的反饋確實不知道這些小技巧。今天,我們來聊一聊在 EcmaScript5/6+ 中的一些小技巧,歡迎評論區(qū)討論下更多技巧。 JSON.stringify 我們平時經常會用到JSON 對象,比如當我們
        推薦度:
        標簽: 操作 小技巧 技巧
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 免费国产黄网站在线观看可以下载| 亚洲一区二区三区久久久久| 色噜噜狠狠色综合免费视频| 九九精品免费视频| 美女羞羞免费视频网站| 午夜视频免费成人| 亚洲成a人无码亚洲成av无码| 久久受www免费人成_看片中文| 国产区在线免费观看| 久久丫精品国产亚洲av不卡| 亚洲制服在线观看| 国产精品极品美女免费观看| 久久久久精品国产亚洲AV无码| 亚洲啪啪免费视频| 亚洲xxxxxx| 午夜寂寞在线一级观看免费| 亚洲人成人网站色www| 西西人体免费视频| 亚洲va在线va天堂va四虎| 污视频网站在线观看免费| 亚洲高清视频一视频二视频三| 精品97国产免费人成视频| 亚洲av日韩av激情亚洲| 久久WWW免费人成一看片| 久久亚洲最大成人网4438| 国产免费怕怕免费视频观看| 成人a毛片视频免费看| 成年轻人网站色免费看| 亚洲成AV人片在WWW| 国产成人99久久亚洲综合精品| 亚洲AV综合永久无码精品天堂| va亚洲va日韩不卡在线观看| 久久免费99精品国产自在现线 | 亚洲乱码卡一卡二卡三| 精品免费国产一区二区| 国产va免费观看| 亚洲理论片在线观看| 日韩精品成人亚洲专区| 久久国产乱子免费精品| 久久综合亚洲色hezyo| 亚洲韩国精品无码一区二区三区|