亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript實用代碼小技巧

 更新時間:2018年08月23日 08:43:19   投稿:laozhang  
在這篇文章中給大家分享了關于JavaScript實用代碼小技巧的相關內(nèi)容,有興趣的朋友們可以參考學習下。

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

JSON.stringify

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

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

首先來看語法:

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

參數(shù):

  • value:將要被序列化的變量的值
  • replacer:替代器??梢允呛瘮?shù)或者是數(shù)組,如果是一個函數(shù),則value 每個屬性都要經(jīng)過這個函數(shù)的處理,該函數(shù)的返回值就是最后被序列化后的值。如果是一個數(shù)組,則要求該數(shù)組的元素是字符串,且這些元素會被當做value 的鍵(key)進行匹配,最后序列化的結果,是只包含該數(shù)組每個元素為key 的值。
  • space:指定輸出數(shù)值的代碼縮進,美化格式之用,可以是數(shù)字或者字符串。如果是數(shù)字(最大為10)的話,代表每行代碼的縮進是多少個空格。如果是字符串的話,該字符串(最多前十個字符)將作顯示在每行代碼之前。

這時候,你應該知道了。我們可以用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 可以相互進行轉(zhuǎn)換。

數(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

可以看出,如果在調(diào)用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 中,=== 和== 是有很大的不同的,== 會將兩邊的變量進行轉(zhuǎn)義,然后將轉(zhuǎn)義后的值進行比較,而=== 是嚴格比較,要求兩邊的變量不僅值要相同,它們自身的類型也要相同。

JavaScript 經(jīng)常被調(diào)侃成一個神奇的語言,就是因為它的轉(zhuǎn)義的特性,而用== 可能會引入一些深埋的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 的對比:

相關文章

  • 實現(xiàn)表格中行點擊時的漸擴效果!

    實現(xiàn)表格中行點擊時的漸擴效果!

    實現(xiàn)表格中行點擊時的漸擴效果!...
    2006-12-12
  • js代碼運行報錯Warning:To?load?an?ES?module,?set?"type":"module"in?the?package.json?or?use?the?.mjs

    js代碼運行報錯Warning:To?load?an?ES?module,?set?"type&q

    最近在學習ES6的過程中,和運行javascript文件時進行了報錯,下面這篇文章主要給大家介紹了關于js代碼運行報錯Warning:To?load?an?ES?module,?set?"type":"module"in?the?package.json?or?use?the?.mjs的相關資料,需要的朋友可以參考下
    2023-04-04
  • Ajax和Comet技術總結

    Ajax和Comet技術總結

    Ajax是一種技術,一種能夠向服務器請求額外的數(shù)據(jù)而無需卸載頁面的技術,能夠使網(wǎng)頁具備更優(yōu)的用戶體驗。Ajax技術的核心是XMLHttpRequest對象(XHR)。本文從XHR開始談起,理解Ajax技術的特點,再對跨域以及Comet等技術進行簡要理解和總結。下面跟著小編一起來看下吧
    2017-02-02
  • 無廢話JavaScript教程(全集)

    無廢話JavaScript教程(全集)

    許多讀者認為我那本《JavaScript語言精髓與編程實踐》讀來辛苦,所以我一直想寫個簡單的讀本。索性,這次就寫個最簡單的吧。
    2008-10-10
  • 再論Javascript下字符串連接的性能

    再論Javascript下字符串連接的性能

    這是個老話題了,之所以再拿出來說,是因為瀏覽器一直在進步,以前最好的方法現(xiàn)在不一定是最好的。
    2011-03-03
  • Javascript中字符串相關常用的使用方法總結

    Javascript中字符串相關常用的使用方法總結

    本篇文章主要介紹了Javascript中字符串相關常用的使用方法。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • JavaScript編寫九九乘法表(兩種任選)

    JavaScript編寫九九乘法表(兩種任選)

    本文主要介紹了JavaScript編寫九九乘法表的兩種方法,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • Lerna入門之管理TypeScript monorepo教程

    Lerna入門之管理TypeScript monorepo教程

    這篇文章主要為大家介紹了Lerna入門之管理TypeScript monorepo教程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • 如何只用echarts做個仿3d地圖功能

    如何只用echarts做個仿3d地圖功能

    由于業(yè)務需求,需要繪制3d地圖,所以下面這篇文章主要給大家介紹了關于如何只用echarts做個仿3d地圖功能的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-09-09
  • BootstrapTable加載按鈕功能實例代碼詳解

    BootstrapTable加載按鈕功能實例代碼詳解

    這篇文章主要介紹了BootstrapTable加載按鈕功能實例代碼詳解,需要的朋友可以參考下
    2017-09-09

最新評論