亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

js中的內部屬性與delete操作符介紹

2019-11-20 11:53:01
字體:
來源:轉載
供稿:網友

在講解Configurable之前,我們首先來看一道面試題:

a = 1;console.log( window.a ); // 1console.log( delete window.a ); // trueconsole.log( window.a ); // undefinedvar b = 2;console.log( window.b ); // 2console.log( delete window.b ); // falseconsole.log( window.b ); // 2

從上面的這道題可以看出兩個的區別:在沒有使用var聲明變量時,使用delete關鍵詞是可以進行刪除的,再次獲取時值就是undefined了;在使用var聲明的變量,使用delete是不能刪除的,再獲取時值依然是2。

1. delete操作符

使用delete刪除變量或屬性時,刪除成功返回true,否則返回false。如上面的例子中,delete無法刪除變量a時,則返回false;而delete能成功刪除變量b,則返回true。

除了上述的兩種情況,還有其他的各種常用變量也有能被delete刪除的,也有不能被刪除的。我們先不管delete這些變量時,為什么會產生這樣的結果,這里只看他的返回值:

刪除delete數組中其中的一個元素:

// 使用for~in是循環不到的,直接忽略到該元素// 使用for()可以得到該元素,但是值是undefinedvar arr = [1, 2, 3, 4];console.log( arr );     	// [1, 2, 3, 4]console.log( delete arr[2] );	// true,刪除成功console.log( arr );      	// [1, 2, undefined, 4]

刪除function類型的變量:

// chrome 不能刪除;火狐可以刪除function func(){}console.log( func );console.log( delete func );console.log( func );

刪除function.length,該length是獲取形參的個數:

function func1(a, b){}console.log( func1.length );   	// 2console.log( delete func1.length );	// true,刪除成功console.log( func1.length );   	// 0

刪除常用變量:

console.log( delete NaN );  	// false,刪除失敗console.log( delete undefined );// falseconsole.log( delete Infinity );	// falseconsole.log( delete null );  	// true,刪除成功

刪除prototype,而不是刪除prototype上的屬性:

function Person(){}Person.prototype.name = "蚊子";console.log( delete Person.prototype );	// false,無法刪除console.log( delete Object.prototype );	// false

刪除數組和字符串的length時:

var arr = [1, 2, 3, 4];console.log( arr.length );    	// 4console.log( delete arr.length ); 	// false,刪除失敗console.log( arr.length );    	// 4var str = 'abcdefg';console.log( str.length );    	// 7console.log( delete str.length ); 	// false,刪除失敗console.log( str.length );    	// 7

刪除obj中的屬性時:

var obj = {name:'wenzi', age:25};console.log( obj.name );   	// wenziconsole.log( delete obj.name );	// true,刪除成功console.log( obj.name );   	// undefinedconsole.log( obj );      	// { age:25 }

刪除實例對象中的屬性時,從以下的輸出結果可以看出,使用delete刪除屬性時,刪除的僅僅是實例對象本身的屬性,而不能刪除prototype上的屬性,即使再刪一次也是刪除掉不的;若要刪除prototype上的屬性的屬性或方法,只能是:delete Person.prototype.name

function Person(){  this.name = 'wenzi';}Person.prototype.name = '蚊子';var student = new Person();console.log( student.name );    // wenziconsole.log( delete student.name ); // true,刪除成功console.log( student.name );    // 蚊子console.log( delete student.name ); // trueconsole.log( student.name );    // 蚊子console.log( delete Person.prototype.name );// true,刪除成功console.log( student.name );    // undefined

2. js的內部屬性

在上面的例子中,有的變量或屬性能夠刪除成功,而有的變量或屬性則無法進行刪除,那是什么決定這個變量或屬性能不能被刪除呢。

ECMA-262第5版定義了JS對象屬性中特征(用于JS引擎,外部無法直接訪問)。ECMAScript中有兩種屬性:數據屬性和訪問器屬性。

2.1 數據屬性

數據屬性指包含一個數據值的位置,可在該位置讀取或寫入值,該屬性有4個供述其行為的特性:

  • [[configurable]]:表示能否使用delete操作符刪除從而重新定義,或能否修改為訪問器屬性。默認為true;
  • [[Enumberable]]:表示是否可通過for-in循環返回屬性。默認true;
  • [[Writable]]:表示是否可修改屬性的值。默認true;
  • [[Value]]:包含該屬性的數據值。讀取/寫入都是該值。默認為undefined;如上面實例對象Person中定義了name屬性,其值為'wenzi',對該值的修改都反正在這個位置

要修改對象屬性的默認特征(默認都為true),可調用Object.defineProperty()方法,它接收三個參數:屬性所在對象,屬性名和一個描述符對象(必須是:configurable、enumberable、writable和value,可設置一個或多個值)。

如下:

var person = {};Object.defineProperty(person, 'name', {  configurable: false,	// 不可刪除,且不能修改為訪問器屬性  writable: false,		// 不可修改  value: 'wenzi'			// name的值為wenzi});console.log( person.name);			// wenziconsole.log( delete person.name );	// false,無法刪除person.name = 'lily';console.log( person.name );			// wenzi

可以看出,delete及重置person.name的值都沒有生效,這就是因為調用defineProperty函數修改了對象屬性的特征;值得注意的是一旦將configurable設置為false,則無法再使用defineProperty將其修改為true(執行會報錯:Uncaught TypeError: Cannot redefine property: name);

2.2 訪問器屬性

它主要包括一對getter和setter函數,在讀取訪問器屬性時,會調用getter返回有效值;寫入訪問器屬性時,調用setter,寫入新值;該屬性有以下4個特征:

  • [[Configurable]]:是否可通過delete操作符刪除重新定義屬性;
  • [[Numberable]]:是否可通過for-in循環查找該屬性;
  • [[Get]]:讀取屬性時自動調用,默認:undefined;
  • [[Set]]:寫入屬性時自動調用,默認:undefined;

訪問器屬性不能直接定義,必須使用defineProperty()來定義,如下:

var person = {  _age: 18};Object.defineProperty(person, 'isAdult', {	Configurable : false,  get: function () {    if (this._age >= 18) {      return true;    } else {      return false;    }  }});console.log( person.isAdult ); // true

不過還是有一點需要額外注意一下,Object.defineProperty()方法設置屬性時,不能同時聲明訪問器屬性(set和get)和數據屬性(writable或者value)。意思就是,某個屬性設置了writable或者value屬性,那么這個屬性就不能聲明get和set了,反之亦然。

如若像下面的方式進行定義,訪問器屬性和數據屬性同時存在:

var o = {};Object.defineProperty(o, 'name', {  value: 'wenzi',  set: function(name) {    myName = name;  },  get: function() {    return myName;  }});

上面的代碼看起來貌似是沒有什么問題,但是真正執行時會報錯,報錯如下:

Uncaught TypeError: Invalid property. A property cannot both have accessors and be writable or have a value

對于數據屬性,可以取得:configurable,enumberable,writable和value;

對于訪問器屬性,可以取得:configurable,enumberable,get和set。

由此我們可知:一個變量或屬性是否可以被刪除,是由其內部屬性Configurable進行控制的,若Configurable為true,則該變量或屬性可以被刪除,否則不能被刪除。

可是我們應該怎么獲取這個Configurable值呢,總不能用delete試試能不能刪除吧。有辦法滴!!

2.3 獲取內部屬性

ES5為我們提供了Object.getOwnPropertyDescriptor(object, property)來獲取內部屬性。

如:

var person = {name:'wenzi'};var desp = Object.getOwnPropertyDescriptor(person, 'name'); // person中的name屬性console.log( desp );	// {value: "wenzi", writable: true, enumerable: true, configurable: true}

通過Object.getOwnPropertyDescriptor(object, property)我們能夠獲取到4個內部屬性,configurable控制著變量或屬性是否可被刪除。這個例子中,person.name的configurable是true,則說明是可以被刪除的:

console.log( person.name );			// wenziconsole.log( delete person.name );	// true,刪除成功console.log( person.name );			// undefined

我們再回到最開始的那個面試題:

a = 1;var desp = Object.getOwnPropertyDescriptor(window, 'a');console.log( desp.configurable ); 	// true,可以刪除var b = 2;var desp = Object.getOwnPropertyDescriptor(window, 'b');console.log( desp.configurable ); 	// false,不能刪除

跟我們使用delete操作刪除變量時產生的結果是一樣的。

3. 總結

別看一個簡簡單單的delete操作,里面其實包含了很多的原理!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩精品免费综合视频在线播放| 日韩精品欧美国产精品忘忧草| 欧美肥老妇视频| 国产精品美女午夜av| 日韩欧美精品中文字幕| 国产69精品久久久久久| 久久伊人精品天天| 日韩福利伦理影院免费| 97成人超碰免| 性色av香蕉一区二区| 正在播放欧美一区| 国产精品男人爽免费视频1| 狠狠久久五月精品中文字幕| 亚洲女人初尝黑人巨大| 欧洲日本亚洲国产区| 日韩电影中文字幕在线观看| 97色在线观看免费视频| 91精品国产高清久久久久久91| 亚洲大胆美女视频| 91精品国产综合久久久久久久久| 久久精品久久精品亚洲人| 国产日产欧美精品| 亚洲国产女人aaa毛片在线| 久久久久国产精品免费| 91国产美女在线观看| 精品久久久91| 国产精品免费观看在线| 国产精品久久久| 欧美日韩电影在线观看| 日韩国产精品一区| 日本亚洲欧洲色| 精品少妇一区二区30p| 亚洲欧洲av一区二区| 亚洲人成网7777777国产| 成人黄色片在线| 久久免费视频这里只有精品| 欧美性猛交xxxx乱大交| 538国产精品视频一区二区| 欧美在线激情视频| 色多多国产成人永久免费网站| 精品久久久久久久久久国产| 国产在线视频91| 亚洲欧美综合v| 97在线观看免费高清| 欧美国产精品va在线观看| 久久久亚洲影院| 欧美性色19p| 欧美亚洲成人xxx| 日韩av免费在线看| 国产亚洲综合久久| 久久99精品久久久久久噜噜| 青青草国产精品一区二区| 久久精品亚洲热| 午夜精品久久久久久久99热浪潮| 57pao国产成人免费| 国产亚洲一区精品| 中文字幕在线观看亚洲| 成人免费在线视频网站| 亚洲一区二区三区xxx视频| 日本不卡视频在线播放| 精品国产91久久久久久老师| 国产精品久久久久久搜索| 国产精品视频一区二区高潮| 久久亚洲精品一区二区| 亚洲码在线观看| 最近中文字幕日韩精品| 国产日本欧美在线观看| 国产欧美精品日韩精品| 国产精品视频1区| 日本精品性网站在线观看| 日韩小视频网址| 欧美丝袜一区二区三区| 91精品久久久久久久久久久久久| 91久久久久久久一区二区| 爽爽爽爽爽爽爽成人免费观看| 亚洲最新在线视频| 国产激情综合五月久久| 色妞久久福利网| 欧美激情视频一区二区| 亚洲娇小xxxx欧美娇小| 亚洲一品av免费观看| 欧美亚洲国产视频小说| 午夜免费日韩视频| 久久中文字幕在线视频| 日韩国产中文字幕| 日本一欧美一欧美一亚洲视频| 欧美激情2020午夜免费观看| 亚洲第一中文字幕| 日韩在线视频一区| 欧美日韩亚洲一区二区| 亚洲在线一区二区| 国产精品视频在线播放| 国产精品一区专区欧美日韩| 日韩av在线免播放器| zzijzzij亚洲日本成熟少妇| 综合久久五月天| 操日韩av在线电影| 国产午夜精品一区二区三区| 成人免费在线视频网站| 国产视频观看一区| 日韩一区二区欧美| 91精品国产高清| 裸体女人亚洲精品一区| 中文字幕亚洲欧美日韩高清| 日韩免费在线免费观看| 国产一区二区三区高清在线观看| 在线观看欧美日韩国产| 在线视频中文亚洲| 久久久电影免费观看完整版| 国产成人精品视频| 91沈先生作品| 国产成人av在线| 亚洲色图偷窥自拍| 久久综合久久八八| 日本sm极度另类视频| 亚洲国语精品自产拍在线观看| 国产午夜精品理论片a级探花| 色悠悠久久88| 欧美黑人xxxⅹ高潮交| 欧美裸体男粗大视频在线观看| 亚洲精品有码在线| 日本亚洲精品在线观看| 一个人看的www久久| 日韩视频永久免费观看| 一本色道久久88综合日韩精品| 日韩中文在线中文网三级| 97精品在线观看| 日韩美女av在线免费观看| 久久精品国产清自在天天线| 中文字幕精品—区二区| 久久久久久12| 亚洲第一中文字幕| 日韩精品视频免费| 91人成网站www| 一区二区三区天堂av| 91免费的视频在线播放| 日韩精品小视频| 亚洲第一中文字幕在线观看| 日韩欧美一区二区在线| 亚洲在线免费观看| 中文字幕九色91在线| 亚洲色图50p| 亚洲欧美国产高清va在线播| 欧美性videos高清精品| 亚洲а∨天堂久久精品喷水| 在线电影av不卡网址| 91精品免费视频| 中国china体内裑精亚洲片| 欧美日韩中文在线观看| 久久久久久久999精品视频| 国产噜噜噜噜噜久久久久久久久| 97在线视频免费| 国产精品96久久久久久| 精品久久久久久久久国产字幕| 欧美高清在线观看| 都市激情亚洲色图| 精品久久久国产精品999| 北条麻妃一区二区三区中文字幕| 亚洲欧美日韩精品久久奇米色影视| 欧美日韩国产中文精品字幕自在自线| 欧美另类极品videosbest最新版本| 欧美专区在线视频| 亚洲女人初尝黑人巨大| 奇米成人av国产一区二区三区|