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

js中的內(nèi)部屬性與delete操作符介紹

 更新時間:2015年08月10日 00:35:45   作者:師少兵  
這篇文章主要介紹了js中的內(nèi)部屬性與delete操作符的相關(guān)資料,需要的朋友可以參考下

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

a = 1;
console.log( window.a ); // 1
console.log( delete window.a ); // true
console.log( window.a ); // undefined

var b = 2;
console.log( window.b ); // 2
console.log( delete window.b ); // false
console.log( window.b ); // 2

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

1. delete操作符

使用delete刪除變量或?qū)傩詴r,刪除成功返回true,否則返回false。如上面的例子中,delete無法刪除變量a時,則返回false;而delete能成功刪除變量b,則返回true。

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

刪除delete數(shù)組中其中的一個元素:

// 使用for~in是循環(huán)不到的,直接忽略到該元素
// 使用for()可以得到該元素,但是值是undefined
var 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是獲取形參的個數(shù):

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

刪除常用變量:

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

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

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

刪除數(shù)組和字符串的length時:

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

var str = 'abcdefg';
console.log( str.length );    	// 7
console.log( delete str.length ); 	// false,刪除失敗
console.log( str.length );    	// 7

刪除obj中的屬性時:

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

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

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

2. js的內(nèi)部屬性

在上面的例子中,有的變量或?qū)傩阅軌騽h除成功,而有的變量或?qū)傩詣t無法進(jìn)行刪除,那是什么決定這個變量或?qū)傩阅懿荒鼙粍h除呢。

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

2.1 數(shù)據(jù)屬性

數(shù)據(jù)屬性指包含一個數(shù)據(jù)值的位置,可在該位置讀取或?qū)懭胫?,該屬性?個供述其行為的特性:

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

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

如下:

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

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

2.2 訪問器屬性

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

  • [[Configurable]]:是否可通過delete操作符刪除重新定義屬性;
  • [[Numberable]]:是否可通過for-in循環(huán)查找該屬性;
  • [[Get]]:讀取屬性時自動調(diào)用,默認(rèn):undefined;
  • [[Set]]:寫入屬性時自動調(diào)用,默認(rèn):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()方法設(shè)置屬性時,不能同時聲明訪問器屬性(set和get)和數(shù)據(jù)屬性(writable或者value)。意思就是,某個屬性設(shè)置了writable或者value屬性,那么這個屬性就不能聲明get和set了,反之亦然。

如若像下面的方式進(jìn)行定義,訪問器屬性和數(shù)據(jù)屬性同時存在:

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

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

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

對于數(shù)據(jù)屬性,可以取得:configurable,enumberable,writable和value;

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

由此我們可知:一個變量或?qū)傩允欠窨梢员粍h除,是由其內(nèi)部屬性Configurable進(jìn)行控制的,若Configurable為true,則該變量或?qū)傩钥梢员粍h除,否則不能被刪除。

可是我們應(yīng)該怎么獲取這個Configurable值呢,總不能用delete試試能不能刪除吧。有辦法滴?。?/p>

2.3 獲取內(nèi)部屬性

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

如:

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個內(nèi)部屬性,configurable控制著變量或?qū)傩允欠窨杀粍h除。這個例子中,person.name的configurable是true,則說明是可以被刪除的:

console.log( person.name );			// wenzi
console.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操作刪除變量時產(chǎn)生的結(jié)果是一樣的。

3. 總結(jié)

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

相關(guān)文章

  • JS實現(xiàn)簡易換圖時鐘功能分析

    JS實現(xiàn)簡易換圖時鐘功能分析

    這篇文章主要介紹了JS實現(xiàn)簡易換圖時鐘功能,結(jié)合實例形式分析了javascript結(jié)合時間函數(shù)定時變換顯示圖片實現(xiàn)時鐘功能的相關(guān)操作技巧,代碼中備有較為詳盡的注釋便于理解,需要的朋友可以參考下
    2018-01-01
  • Javascript讓DEDECMS告別手寫Tag

    Javascript讓DEDECMS告別手寫Tag

    dedecms在編輯修改內(nèi)容時,TAG標(biāo)簽需要手動輸,中文的Tag, 中間還得用半角字符','分隔, 輸入法切來切去很不方便, 于是動手改后臺代碼, 利用后臺的tags_main.php, 讓dedecms添加內(nèi)容時能去tags_main里去選擇.
    2014-09-09
  • JavaScript常用事件介紹

    JavaScript常用事件介紹

    今天小編就為大家分享一篇關(guān)于JavaScript常用事件介紹,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • JavaScript實現(xiàn)的圓形浮動標(biāo)簽云效果實例

    JavaScript實現(xiàn)的圓形浮動標(biāo)簽云效果實例

    這篇文章主要介紹了JavaScript實現(xiàn)的圓形浮動標(biāo)簽云效果,涉及javascript字符串與數(shù)組的遍歷、排序操作以及元素樣式動態(tài)操作與數(shù)學(xué)運算等相關(guān)技巧,是非常實用的一段代碼,需要的朋友可以參考下
    2015-08-08
  • JS監(jiān)控關(guān)閉瀏覽器操作的實例詳解

    JS監(jiān)控關(guān)閉瀏覽器操作的實例詳解

    這篇文章主要介紹了JS監(jiān)控關(guān)閉瀏覽器操作的實例詳解的相關(guān)資料,希望通過本大家能幫助到大家,需要的朋友可以參考下
    2017-09-09
  • 用js替換除數(shù)字與逗號以外的所有字符的代碼

    用js替換除數(shù)字與逗號以外的所有字符的代碼

    用js實現(xiàn)的替換除數(shù)字與逗號以外的所有字符的代碼,因為需要去除重復(fù),這樣的話就會有很多的逗號需要替換
    2014-06-06
  • electron 安裝,調(diào)試,打包的具體使用

    electron 安裝,調(diào)試,打包的具體使用

    這篇文章主要介紹了electron 安裝,調(diào)試,打包的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 原生JavaScript實現(xiàn)精美的淘寶輪播圖效果示例【附demo源碼下載】

    原生JavaScript實現(xiàn)精美的淘寶輪播圖效果示例【附demo源碼下載】

    這篇文章主要介紹了原生JavaScript實現(xiàn)精美的淘寶輪播圖效果,結(jié)合完整實例形式詳細(xì)分析了javascript實現(xiàn)淘寶輪播圖功能的相關(guān)HTML布局、css及js核心功能代碼,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下
    2017-05-05
  • js百度地圖鼠標(biāo)滾輪縮放導(dǎo)致地圖中心點偏移問題

    js百度地圖鼠標(biāo)滾輪縮放導(dǎo)致地圖中心點偏移問題

    本文主要介紹了js百度地圖鼠標(biāo)滾輪縮放導(dǎo)致地圖中心點偏移問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • JavaScript中關(guān)于iframe滾動條的去除和保留

    JavaScript中關(guān)于iframe滾動條的去除和保留

    在開發(fā)中經(jīng)常遇到去掉全部的滾動條,去掉右邊的滾動條且保留底下的滾動條,去掉底下的滾動條且保留右邊的滾動條,大家基于js是怎么實現(xiàn)的呢?下面小編通過本文給大家詳細(xì)介紹下,對js iframe滾動條相關(guān)知識感興趣的朋友一起學(xué)習(xí)吧
    2016-11-11

最新評論