亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.430618.com 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

數組去重

    var arr = [1, 2, 3, 3, 4];
    console.log(...new Set(arr))
    >> [1, 2, 3, 4]

數組和布爾

有時我們需要過濾數組中值為 false 的值. 例如(0, undefined, null, false), 你可能不知道這樣的技巧

 var myArray = [1, 0 , undefined, null, false];
 myArray.filter(Boolean);
 >> [1]

是不是很簡單, 只需要傳入一個 Boolean 函數即可.

創建一個空對象

有時我們需要創建一個純凈的對象, 不包含什么原型鏈等等. 一般創建空對象最直接方式通過字面量 {}, 但這個對象中依然存在 __proto__ 屬性來指向 Object.prototype 等等.

    let dict = Object.create(null);
 
    dict.__proto__ === "undefined" 

合并對象

在JAVAScript中合并多個對象的需求一直存在, 比如在傳參時需要把表單參數和分頁參數進行合并后再傳遞給后端

    const page = {
        current: 1,
        pageSize: 10
    }
 
    const form = {
        name: "",
        sex: ""
    }
 
    const params = {...form, ...page};
 
    /*
        {
            name: "",
            sex: "",
            current: 1,
            pageSize: 10
 
        }
    *

利用ES6提供的擴展運算符讓對象合并變得很簡單.

函數參數必須

ES6中可以給參數指定默認值,確實帶來很多便利. 如果需要檢測某些參數是必傳時,可以這么做

    const isRequired = () => { throw new Error('param is required'); };
 
    const hello = (name = isRequired()) => { console.log(`hello ${name}`) };
 
    // 這里將拋出一個錯誤,因為名字時必須
    hello();
    // 這也將拋出一個錯誤
    hello(undefined);
 
    // 正常
    hello(null);
    hello('David'); 

解構賦值時使用別名

解構賦值是一個非常受歡迎的JavaScript功能,但有時我們更喜歡用其他名稱引用這些屬性,所以我們可以利用別名來完成:

    const obj = { x: 1 };
 
    // Grabs obj.x as { x }
    const { x } = obj;
 
    // Grabs obj.x as { otherName }
    const { x: otherName } = obj;

獲取查詢參數

多年來,我們編寫粗糙的正則表達式來獲取查詢字符串值,但那些日子已經一去不復返了; 現在我們可以通過 URLSearchParams API 來獲取查詢參數

在不使用 URLSearchParams 我們通過正則的方式來完成獲取查詢參數的, 如下:

  function getQueryString(name) {
    var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
    var r = window.location.search.substr(1).match(reg);
    return r ? r[2] : null;
  }

使用 URLSearchParams 之后:

    // 假設地址欄中查詢參數是這樣 "?post=1234&action=edit"
 
    var urlParams = new URLSearchParams(window.location.search);
 
    console.log(urlParams.has('post')); // true
    console.log(urlParams.get('action')); // "edit"
    console.log(urlParams.getAll('action')); // ["edit"]
    console.log(urlParams.toString()); // "?post=1234&action=edit"
    console.log(urlParams.Append('active', '1')); // "?post=1234&action=edit&active=1"

相比之前使用起來更加容易了.

你不得不知道的七個JavaScript小技巧

分享到:
標簽:JavaScript
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定