日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳解JS中的對象字面量

瀏覽:226日期:2024-03-29 10:09:05
前言

在 ES6 之前,js中的對象字面量(也稱為對象初始化器)是非常基礎的。可以定義兩種類型的屬性:

鍵值對{name1: value1} 獲取器{ get name(){..} }和 設置器{ set name(val){..}}的計算屬性值

var myObject = { myString: ’value 1’, get myNumber() { return this._myNumber; }, set myNumber(value) { this._myNumber = Number(value); },};myObject.myString; // => ’value 1’myObject.myNumber = ’15’;myObject.myNumber; // => 15

js是一種基于原型的語言,因此一切都是對象。 在對象創建,配置和訪問原型時,必須提供一種易于構造的語言。

定義一個對象并設置它的原型是一個常見的任務。最好的方式是直接在對象字面量使用一條語句來設置原型。

不幸的是,字面量的局限性不允許用一個簡單的解決方案來實現這一點。必須結合使用object.create()和對象字面量來設置原型。

var myProto = { propertyExists: function(name) { return name in this; }};var myNumbers = Object.create(myProto);myNumbers[’arrat’] = [1, 6, 7];myNumbers.propertyExists(’array’); // => truemyNumbers.propertyExists(’collection’); // => false

我認為這種解決方案不夠靈活。JS 是基于原型的,為什么要用原型創建對象那么麻煩?

幸運的是,JS 也在慢慢完善。JS 中很多令人沮喪的問題都是逐步解決的。

本文演示了 ES 6 如何解決上述問題,并使用額外的功能改進對象字面量。

在對象構造上設置原型 方法的聲明 super 調用 計算屬性名1. 在對象構造上設置原型

如你所知,訪問現有對象原型的一種方法是使用 getter 屬性__proto__:

var myObject = { name: ’Hello World!’,};myObject.__proto__; // => {}myObject.__proto__.isPrototypeOf(myObject); // => true

myObject.__ proto__返回myObject的原型對象。

請注意,不建議將object.__ proto__用作getter/setter。替代方法應考慮使用Object.getPrototypeOf()和Object.setPrototypeOf()。

ES6允許使用__proto__作為屬性名,并在{__proto__:protoObject}中設置原型。

接著,咱們使用__proto__屬性進行對象初始化,并優化上面的代碼:

var myProto = { propertyExists: function(name) { return name in this; },};var myNumbers = { __proto__: myProto, array: [1, 6, 7],};myNumbers.propertyExists(’array’); // => truemyNumbers.propertyExists(’collection’); // => false

myNumbers對象是使用特殊屬性名proto與創建原型myProto,這次咱們使用一條語句就創建,沒有像上面還需要object.create()這樣的附加函數。

如你所看,使用__proto__進行編碼很簡單,我一直喜歡簡單明了的解決方案。

說點脫離主題。 我覺得奇怪的是,簡單靈活的解決方案需要大量的工作和設計。如果解決方案很簡單,你可能會認為設計起來很容易。但是反之亦然:

要使它簡單明了是很復雜的 把它變得復雜和難以理解是很容易的

如果某些東西看起來太復雜或難以使用,則可能還需要進一步的完善。

1.1 __proto__用法的特殊情況

即使__proto__看起來很簡單,您也應該注意一些特殊情況。

在對象字面量中只能使用__proto__一次,否則 JS 會報錯:

var object = { __proto__: { toString: function() { return ’[object Numbers]’ } }, numbers: [1, 5, 89], __proto__: { toString: function() { return ’[object ArrayOfNumbers]’ } }};

上面示例中的對象字面量中使用兩次__proto__屬性,這是不允許的。在這種情況下,將在會拋出錯誤:SyntaxError: Duplicate __proto__ fields are not allowed in object literals。

JS 約束只能用一個對象或null作為__proto__屬性的值。 任何使用原始類型(字符串,數字,布爾值)或undefined類型都將被忽略,并且不會更改對象的原型。

var objUndefined = { __proto__: undefined,};Object.getPrototypeOf(objUndefined); // => {}var objNumber = { __proto__: 15,};Object.getPrototypeOf(objNumber); // => {}

對象字面量使用undefined和 數字15來設置__proto__值。 因為僅允許將對象或null用作原型,所以__proto__值將被忽略,但objUndefined和objNumber仍具有其默認原型:純 JS 對象{}, 。

當然,嘗試使用基本類型來設置對象的原型也會很奇怪。

當對象字面具有計算結果為’__proto__’的字符串時{[’__proto__’]:protoObj },也要小心。 以這種方式創建的屬性不會更改對象的原型,而只是使用鍵’__proto__’創建一個擁有的屬性

2.簡寫方法定義

可以使用較短的語法在對象常量中聲明方法,以省略function關鍵字和:冒號的方式。 這被稱為簡寫方法定義。

接著,咱們使用簡寫的方法來定義一些方法:

var collection = { items: [], add(item) { this.items.push(item); }, get(index) { return this.items[index]; },};collection.add(15);collection.add(3);collection.get(0); // => 15

一個很好的好處是,以這種方式聲明的方法被命名為函數,這對于調試目的很有用。 從上面示例中執行collection.add.name會返回函數名稱“add”。

3. super 的使用

JS 一個有趣的改進是使用super關鍵字作為從原型鏈訪問繼承的屬性的能力。 看下面的例子:

var calc = { numbers: null, sumElements() { return this.numbers.reduce(function(a, b) { return a + b; }); },};var numbers = { __proto__: calc, numbers: [4, 6, 7], sumElements() { if (this.numbers == null || this.numbers.length === 0) { return 0; } return super.sumElements(); },};numbers.sumElements(); // => 17

calc是numbers對象的原型。 在numbers的sumElements方法中,可以使用super關鍵字從原型訪問方法:super.sumElements()

最終,super是從對象原型鏈訪問繼承的屬性的快捷方式。

在前面的示例中,可以嘗試直接執行calc.sumElements()來調用原型,會報錯。 然而,super.sumElements()可以正確調用,因為它訪問對象的原型鏈。并確保原型中的sumElements()方法使用this.numbers正確訪問數組。

super存在清楚地表明繼承的屬性將被使用。

3.1 super 使用限制

super只能在對象字面量的簡寫方法定義內使用。

如果試圖從普通方法聲明{ name: function(){} }訪問它,JS 將拋出一個錯誤:

var calc = { numbers: null, sumElements() { return this.numbers.reduce(function(a, b) { return a + b; }); },};var numbers = { __proto__: calc, numbers: [4, 6, 7], sumElements: function() { if (this.numbers == null || this.numbers.length === 0) { return 0; } return super.sumElements(); },};// Throws SyntaxError: ’super’ keyword unexpected herenumbers.sumElements();

方法sumElements被定義為一個屬性:sumElements: function(){…}。因為super只能在簡寫方法中使用,所以在這種情況下調用它會拋出SyntaxError: ’super’ keyword unexpected here。

此限制在很大程度上不影響對象字面量的聲明方式。 由于語法較短,因此通常最好使用簡寫方法定義。

4.計算屬性名

在 ES6 之前,對象初始化使用的是字面量的形式,通常是靜態字符串。 要創建具有計算名稱的屬性,就必須使用屬性訪問器。

function prefix(prefStr, name) { return prefStr + ’_’ + name;}var object = {};object[prefix(’number’, ’pi’)] = 3.14;object[prefix(’bool’, ’false’)] = false;object; // => { number_pi: 3.14, bool_false: false }

當然,這種定義屬性的方式是令人愉快的。

接著使用簡寫方式來改完上面的例子:

function prefix(prefStr, name) { return prefStr + ’_’ + name;}var object = { [prefix(’number’, ’pi’)]: 3.14, [prefix(’bool’, ’false’)]: false,};object; // => { number_pi: 3.14, bool_false: false }

[prefix(’number’,’pi’)]通過計算prefix(’number’, ’pi’)表達式(即’number_pi’)來設置屬性名稱。

相應地,[prefix(’bool’, ’false’)]將第二個屬性名稱設置為’bool_false’。

4.1 symbol 作為屬性名稱

symbol 也可以用作計算的屬性名稱。 只要確保將它們包括在方括號中即可:{[Symbol(’name’)]:’Prop value’}

例如,用特殊屬性Symbol.iterator并迭代對象自身的屬性名稱。 如下示例所示:

var object = { number1: 14, number2: 15, string1: ’hello’, string2: ’world’, [Symbol.iterator]: function *() { var own = Object.getOwnPropertyNames(this), prop; while(prop = own.pop()) { yield prop; } }}[...object]; // => [’number1’, ’number2’, ’string1’, ’string2’]

[Symbol.iterator]: function *() { }定義一個屬性,該屬性用于迭代對象的自有屬性。 展開運算符[... object]使用迭代器并返回自有的屬性的列表

5.剩余和展開屬性

剩余屬性允許從對象中收集在分配銷毀后剩下的屬性。

下面的示例在解構對象之后收集剩余的屬性:

var object = { propA: 1, propB: 2, propC: 3,};let { propA, ...restObject } = object;propA; // => 1restObject; // => { propB: 2, propC: 3 }

展開屬性允許將源對象的自有屬性復制到對象文字面量中。 在此示例中,對象字面量從源對象收集到對象的其他屬性:

var source = { propB: 2, propC: 3,};var object = { propA: 1, ...source,};object; // => { propA: 1, propB: 2, propC: 3 }6.總結

在 ES6 中,即使是作為對象字面量的相對較小的結構也得到了相當大的改進。

可以使用__proto__屬性名稱直接從初始化器設置對象的原型。 這比使用Object.create()更容易。

請注意,__proto__是 ES6 標準附件B的一部分,不鼓勵使用。 該附件實現對于瀏覽器是必需的,但對于其他環境是可選的。NodeJS 4、5和6支持此功能。

現在方法聲明的形式更短,因此不必輸入function關鍵字。 在簡化方法中,可以使用super關 鍵字,該關鍵字可以輕松訪問對象原型鏈中的繼承屬性。

如果屬性名稱是在運行時計算的,那么現在您可以使用計算的屬性名稱[expression]來初始化對象。

以上就是詳解JS中的對象字面量的詳細內容,更多關于JS對象字面量的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲免费一区二区| 国产欧美丝祙| 久久麻豆视频| 韩国一区二区三区视频| 免费亚洲一区| 久久精品理论片| 青草久久视频| 国产精品午夜av| 精品国产麻豆| 在线日韩一区| 丝袜脚交一区二区| 亚洲丝袜美腿一区| 亚洲3区在线| 国产毛片久久久| 日本精品黄色| 欧美日韩国产精品一区二区亚洲| 在线精品视频在线观看高清| 三级欧美在线一区| 国产精品一区二区免费福利视频| 国产福利资源一区| 日韩成人亚洲| 欧美一区二区三区高清视频| 午夜在线一区| 国产欧美日韩影院| 国产精品精品| 亚洲日韩视频| 麻豆成全视频免费观看在线看| 精品1区2区3区4区| 国产精品亚洲综合久久| 日本久久成人网| 91免费精品国偷自产在线在线| 精品日韩在线| 久久国产精品久久w女人spa| 国产亚洲精品美女久久久久久久久久| 久久精品伊人| 欧美影院三区| 日韩精品一区二区三区中文| 激情久久一区二区| 亚洲婷婷丁香| 久久精品高清| 国产情侣久久| 日韩一区欧美二区| 久久精品动漫| 国产一区二区精品久| 99亚洲视频| 中文在线а√在线8| 亚洲日本三级| 精品一二三区| 免费在线欧美视频| 欧美亚洲国产激情| 91综合视频| 日本不卡视频在线观看| 亚洲v在线看| 日韩在线欧美| 精品日本视频| 精品国产a一区二区三区v免费| 欧美亚洲一区二区三区| 伊人www22综合色| 丝袜美腿高跟呻吟高潮一区| 伊人精品一区| 99久久夜色精品国产亚洲1000部| 久久精品国产福利| 国产美女精品视频免费播放软件| 四虎国产精品免费久久| 石原莉奈一区二区三区在线观看 | 亚洲午夜免费| 蜜桃av一区| 丝袜美腿亚洲一区| 免费人成网站在线观看欧美高清| 伊人久久亚洲美女图片| 午夜在线观看免费一区| 亚洲免费观看高清完整版在线观| 亚洲开心激情| 久久国产麻豆精品| 久久av偷拍| av中文资源在线资源免费观看| 岛国av在线网站| 激情自拍一区| 免费高清在线一区| 蜜臀av一区二区三区| 涩涩涩久久久成人精品| 69堂免费精品视频在线播放| 少妇精品在线| 久久福利在线| 青青久久av| 亚洲精品精选| 久久精品国产福利| 欧美午夜精品一区二区三区电影| 亚洲一级特黄| 天堂av在线一区| 麻豆国产一区| 欧美日韩视频| 国产精品网站在线看| 日韩不卡免费高清视频| 欧美成人久久| 日韩中出av| 国产v日韩v欧美v| 免费观看在线综合| 成人午夜在线| 四虎精品永久免费| 91精品一区国产高清在线gif| 亚洲精品一二三**| 成人片免费看| 91午夜精品| 久久先锋影音| 久久精品免费一区二区三区| 欧美日韩99| 一区二区国产在线| 99精品视频在线| 日本特黄久久久高潮| 日韩精品免费一区二区在线观看| 婷婷五月色综合香五月| 黄色成人精品网站| 91精品亚洲| 91日韩在线| 久久亚洲人体| 久久精品 人人爱| 蜜桃av一区二区在线观看| 天堂网av成人| 午夜精品久久久久久久久久蜜桃| 国产精品magnet| 日本少妇一区二区| 伊人久久亚洲| 首页国产欧美日韩丝袜| 国产一区二区三区天码| 国产日韩一区| 国产日韩欧美| 精品久久一区| 亚洲天堂日韩在线| 亚洲欧美日本视频在线观看| 久久97视频| 日本视频一区二区| 亚洲精品美女91| 在线看片一区| 国产精品1区| 日本一区二区三区中文字幕| 国产精品日本一区二区三区在线| 精品国产乱码久久久久久樱花 | 日本不卡免费高清视频在线| 免费在线日韩av| 国产精品一区二区三区av| 欧美日韩精品一区二区三区在线观看| 国产精品97| 午夜在线一区二区| 精品免费视频| 欧美日韩免费看片| 欧美激情另类| 最新中文字幕在线播放| 亚洲播播91| 免费美女久久99| 精品视频网站| 99riav国产精品| 一区在线免费| 91成人在线| 亚洲爱爱视频| 国产精品大片| 久久久精品久久久久久96| 免费毛片在线不卡| 亚洲69av| 久久国产精品成人免费观看的软件| 伊人久久亚洲美女图片| 国产精品网站在线看| 欧美一级精品| 麻豆成人在线观看| 在线成人直播| 国产96在线亚洲| 亚洲永久精品唐人导航网址| 91精品国产自产精品男人的天堂| 精品一区二区三区在线观看视频| 欧美精品一区二区久久| 国产欧美激情| 久久亚洲欧洲| 久久久天天操| 国产精品第一| 午夜精品影视国产一区在线麻豆| 日韩精品免费一区二区三区| 日韩不卡一二三区| 黄色亚洲免费| 欧美不卡高清一区二区三区| 欧美日韩18| 日本不卡不码高清免费观看| 国产综合亚洲精品一区二| 国产精品探花在线观看| 亚洲精品字幕| 亚洲精品888| 国产99久久久国产精品成人免费| 精品欠久久久中文字幕加勒比| 亚洲精品大片| 亚洲综合图色| 日韩中文字幕1| 99国产精品99久久久久久粉嫩| 99久久激情| 欧美亚洲在线日韩| 私拍精品福利视频在线一区| 肉色欧美久久久久久久免费看| 久久中文字幕导航| 麻豆国产精品视频| 国产午夜久久av| 国产欧美一区| 久久男人av|