JavaScript優(yōu)雅處理對(duì)象的6種方法
前言
和其他編程語言一樣,JavaScript 有自己的數(shù)據(jù)類型,如數(shù)字、字符串、數(shù)組、對(duì)象等。而對(duì)象在JavaScript中是一種非常重要的數(shù)據(jù)類型,它們有很多有用的方法,在平常項(xiàng)目開發(fā)中可以使用這些方法容易地處理對(duì)象。
本文介紹6個(gè)在項(xiàng)目中用得上的方法,趁此機(jī)會(huì)加深其使用方法。
1、Object.freeze()
Object.freeze()
方法可以防止對(duì)象中的數(shù)據(jù)被修改,即凍結(jié)一個(gè)對(duì)象,這樣不能向這個(gè)對(duì)象 添加、更新或刪除屬性。
const author = { name: "Quintion", city: "Shenzhen", age: 18, validation: true, }; Object.freeze(author); author.name = "QuintionTang"; author.province = "Guangdong"; delete author.age; console.log(author); // { name: 'Quintion', city: 'Shenzhen', age: 18, validation: true }
如上面的代碼,更新屬性name
、新增屬性province
、刪除屬性age
,最終對(duì)象都沒有任何改變。
2、Object.seal()
Object.seal()
方法有點(diǎn)類似于 Object.freeze()
。阻止向?qū)ο筇砑有碌膶傩院蛣h除屬性,但允許更改和更新現(xiàn)有屬性。
const author = { name: "Quintion", city: "Shenzhen", age: 18, validation: true, }; Object.seal(author); author.name = "QuintionTang"; author.province = "Guangdong"; delete author.age; console.log(author); // { name: 'QuintionTang', city: 'Shenzhen', age: 18, validation: true }
從上面代碼可以看到,新增屬性和刪除屬性都無效,只有更新屬性name
生效了。
3、Object.keys()
Object.keys()
方法會(huì)返回一個(gè)數(shù)組,該數(shù)組包含參數(shù)對(duì)象的所有鍵的名稱,數(shù)組中屬性名的排列順序和正常循環(huán)遍歷該對(duì)象時(shí)返回的順序一致 。
看看下面的代碼:
const author = { name: "Quintion", city: "Shenzhen", age: 18, validation: true, }; console.log(Object.keys(author)); // [ 'name', 'city', 'age', 'validation' ]
可以看到上面的代碼中打印的結(jié)果是一個(gè)包含鍵作為輸出的數(shù)組。輸出的結(jié)果可以使用數(shù)組的方法進(jìn)行處理或者迭代。
console.log(Object.keys(author).length); // 4
4、Object.values()
Object.values()
和 Object.keys()
類似,不過Object.values()
是獲取對(duì)象內(nèi)素有屬性的值,返回值組成的數(shù)組。
const author = { name: "Quintion", city: "Shenzhen", age: 18, validation: true, }; console.log(Object.values(author)); // [ 'Quintion', 'Shenzhen', 18, true ]
5、Object.create()
Object.create()
基于現(xiàn)有對(duì)象的原型__proto__
創(chuàng)建一個(gè)新對(duì)象,先來看下面代碼:
const author = { firstName: "Quintion", lastName: "Tang", fullName() { return `${this.firstName} ${this.lastName}`; }, }; const newAuthor = Object.create(author); console.log(newAuthor); // {} newAuthor.firstName = "Ronb"; newAuthor.lastName = "Joy"; console.log(newAuthor.fullName()); // Ronb Joy
在上面的代碼中,使用object. create()
創(chuàng)建一個(gè)具有author
對(duì)象原型的新對(duì)象newAuthor
。這樣在新對(duì)象newAuthor
中可以像改變author
對(duì)象所擁有的屬性值一樣改變相應(yīng)的屬性值,這個(gè)看起來是不有點(diǎn)像繼承,沒錯(cuò), 使用 Object.create
可以實(shí)現(xiàn)類式繼承。
6、Object.entries()
Object.entries() 允許獲取對(duì)象的鍵和值,返回一個(gè)多維數(shù)組,其中每一維包含每個(gè)鍵和值,如[鍵 , 值]
const author = { firstName: "Quintion", lastName: "Tang", fullName() { return `${this.firstName} ${this.lastName}`; }, }; console.log(Object.entries(author));
輸出的結(jié)果如下:
[ [ 'firstName', 'Quintion' ], [ 'lastName', 'Tang' ], [ 'fullName', [Function: fullName] ] ]
總結(jié)
本文對(duì)對(duì)象常見的6個(gè)方法做了簡單的介紹,并提供了相應(yīng)的示例代碼,在實(shí)際編碼處理對(duì)象的過程中,使用上面的方法可以讓代碼變得更加優(yōu)雅。
到此這篇關(guān)于JavaScript優(yōu)雅處理對(duì)象的6種方法的文章就介紹到這了,更多相關(guān)JavaScript處理對(duì)象內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
- 使用js模擬類繼承小例子,學(xué)習(xí)js面向?qū)ο蟮呐笥芽梢詤⒖枷隆?/div> 2010-07-07
關(guān)于HTTP傳輸中g(shù)zip壓縮的秘密探索分析
Gzip是一種流行的文件壓縮算法,現(xiàn)在的應(yīng)用十分廣泛,尤其是在Linux平臺(tái)。下面這篇文章主要給大家介紹了關(guān)于HTTP傳輸中g(shù)zip壓縮的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01js Canvas實(shí)現(xiàn)圓形時(shí)鐘教程
這篇文章主要為大家詳細(xì)介紹了HTML5 Canvas實(shí)現(xiàn)圓形時(shí)鐘簡易教程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09微信小程序?qū)崿F(xiàn)點(diǎn)擊圖片放大預(yù)覽
這篇文章主要為大家詳細(xì)介紹了小程序?qū)崿F(xiàn)點(diǎn)擊圖片放大預(yù)覽功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10JavaScript實(shí)現(xiàn)旋轉(zhuǎn)輪播圖
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)旋轉(zhuǎn)輪播圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08javascript 動(dòng)態(tài)修改css樣式方法匯總(四種方法)
為了達(dá)到某種特殊的效果我們需要用Javascript動(dòng)態(tài)的去更改某一個(gè)標(biāo)簽的Css屬性,如何動(dòng)態(tài)修改css樣式呢?面對(duì)這個(gè)問題,小編帶領(lǐng)大家來解決javascript動(dòng)態(tài)修改css樣式,小伙伴們都快來學(xué)習(xí)吧2015-08-08JavaScript中運(yùn)算符與數(shù)組擴(kuò)展詳細(xì)講解
這篇文章主要介紹了JavaScript中運(yùn)算符與數(shù)組擴(kuò)展方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-11-11JS如何獲取指定范圍內(nèi)的隨機(jī)數(shù)含小數(shù)
這篇文章主要介紹了JS如何獲取指定范圍內(nèi)的隨機(jī)數(shù)含小數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12最新評(píng)論