国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

8 個有用的JS技巧(推薦)

2024-05-06 16:53:00
字體:
來源:轉載
供稿:網友

為了保證的可讀性,本文采用意譯而非直譯。

想閱讀更多優質文章請猛戳GitHub博客,一年百來篇優質文章等著你!

這些技巧可能大家大部分都用過了,如果用過就當作加深點映像,如果沒有遇到過,就當作學會了幾個技巧。

1. 確保數組值

使用 grid ,需要重新創建原始數據,并且每行的列長度可能不匹配, 為了確保不匹配行之間的長度相等,可以使用Array.fill方法。

let array = Array(5).fill('');console.log(array); // outputs (5) ["", "", "", "", ""]

2. 獲取數組唯一值

ES6 提供了從數組中提取惟一值的兩種非常簡潔的方法。不幸的是,它們不能很好地處理非基本類型的數組。在本文中,主要關注基本數據類型。

const cars = [  'Mazda',   'Ford',   'Renault',   'Opel',   'Mazda']const uniqueWithArrayFrom = Array.from(new Set(cars));console.log(uniqueWithArrayFrom); // outputs ["Mazda", "Ford", "Renault", "Opel"]const uniqueWithSpreadOperator = [...new Set(cars)];console.log(uniqueWithSpreadOperator);// outputs ["Mazda", "Ford", "Renault", "Opel"]

3.使用展開運算符合并對象和對象數組

對象合并是很常見的事情,我們可以使用新的ES6特性來更好,更簡潔的處理合并的過程。

// merging objectsconst product = { name: 'Milk', packaging: 'Plastic', price: '5$' }const manufacturer = { name: 'Company Name', address: 'The Company Address' }const productManufacturer = { ...product, ...manufacturer };console.log(productManufacturer); // outputs { name: "Company Name", packaging: "Plastic", price: "5$", address: "The Company Address" }// merging an array of objects into oneconst cities = [  { name: 'Paris', visited: 'no' },  { name: 'Lyon', visited: 'no' },  { name: 'Marseille', visited: 'yes' },  { name: 'Rome', visited: 'yes' },  { name: 'Milan', visited: 'no' },  { name: 'Palermo', visited: 'yes' },  { name: 'Genoa', visited: 'yes' },  { name: 'Berlin', visited: 'no' },  { name: 'Hamburg', visited: 'yes' },  { name: 'New York', visited: 'yes' }];const result = cities.reduce((accumulator, item) => { return {  ...accumulator,  [item.name]: item.visited }}, {});console.log(result);/* outputsBerlin: "no"Genoa: "yes"Hamburg: "yes"Lyon: "no"Marseille: "yes"Milan: "no"New York: "yes"Palermo: "yes"Paris: "no"Rome: "yes"*/

4. 數組 map 的方法 (不使用Array.Map)

另一種數組 map 的實現的方式,不用 Array.map。

Array.from 還可以接受第二個參數,作用類似于數組的map方法,用來對每個元素進行處理,將處理后的值放入返回的數組。如下:

const cities = [  { name: 'Paris', visited: 'no' },  { name: 'Lyon', visited: 'no' },  { name: 'Marseille', visited: 'yes' },  { name: 'Rome', visited: 'yes' },  { name: 'Milan', visited: 'no' },  { name: 'Palermo', visited: 'yes' },  { name: 'Genoa', visited: 'yes' },  { name: 'Berlin', visited: 'no' },  { name: 'Hamburg', visited: 'yes' },  { name: 'New York', visited: 'yes' }];const cityNames = Array.from(cities, ({ name}) => name);console.log(cityNames);// outputs ["Paris", "Lyon", "Marseille", "Rome", "Milan", "Palermo", "Genoa", "Berlin", "Hamburg", "New York"]

5. 有條件的對象屬性

不再需要根據一個條件創建兩個不同的對象,可以使用展開運算符號來處理。

nst getUser = (emailIncluded) => { return {  name: 'John',  surname: 'Doe',  ...emailIncluded && { email : 'john@doe.com' } }}const user = getUser(true);console.log(user); // outputs { name: "John", surname: "Doe", email: "john@doe.com" }const userWithoutEmail = getUser(false);console.log(userWithoutEmail); // outputs { name: "John", surname: "Doe" }

6. 解構原始數據

有時候一個對象包含很多屬性,而我們只需要其中的幾個,這里可以使用解構方式來提取我們需要的屬性。如一個用戶對象內容如下:

const rawUser = {  name: 'John',  surname: 'Doe',  email: 'john@doe.com',  displayName: 'SuperCoolJohn',  joined: '2016-05-05',  image: 'path-to-the-image',  followers: 45  ...}

我們需要提取出兩個部分,分別是用戶及用戶信息,這時可以這樣做:

let user = {}, userDetails = {};({ name: user.name, surname: user.surname, ...userDetails } = rawUser);console.log(user); // outputs { name: "John", surname: "Doe" }console.log(userDetails); // outputs { email: "john@doe.com", displayName: "SuperCoolJohn", joined: "2016-05-05", image: "path-to-the-image", followers: 45 }

7. 動態屬性名

早期,如果屬性名需要是動態的,我們首先必須聲明一個對象,然后分配一個屬性。這些日子已經過去了,有了ES6特性,我們可以做到這一點。

const dynamic = 'email';let user = {  name: 'John',  [dynamic]: 'john@doe.com'}console.log(user); // outputs { name: "John", email: "john@doe.com" }

8.字符串插值

在用例中,如果正在構建一個基于模板的helper組件,那么這一點就會非常突出,它使動態模板連接容易得多。

const user = { name: 'John', surname: 'Doe', details: {  email: 'john@doe.com',  displayName: 'SuperCoolJohn',  joined: '2016-05-05',  image: 'path-to-the-image',  followers: 45 }}const printUserInfo = (user) => {  const text = `The user is ${user.name} ${user.surname}. Email: ${user.details.email}. Display Name: ${user.details.displayName}. ${user.name} has ${user.details.followers} followers.` console.log(text);}printUserInfo(user);// outputs 'The user is John Doe. Email: john@doe.com. Display Name: SuperCoolJohn. John has 45 followers.'

譯者:前端小智

原文:https://devinduct.com/blogpost/26/8-useful-javascript-tricks

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 新龙县| 肥西县| 晋州市| 视频| 靖边县| 乐亭县| 革吉县| 兰溪市| 抚顺市| 漯河市| 肥西县| 光泽县| 兰考县| 石阡县| 封开县| 台湾省| 岳西县| 新宁县| 江源县| 定边县| 长汀县| 邳州市| 六枝特区| 舞阳县| 绵阳市| 天气| 阿勒泰市| 弥勒县| 都兰县| 汽车| 烟台市| 榆中县| 习水县| 大理市| 锡林郭勒盟| 北流市| 正镶白旗| 西盟| 满洲里市| 凌源市| 凤山市|