DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> Javascript學習筆記 delete運算符
Javascript學習筆記 delete運算符
編輯:關於JavaScript     
一、語法

delete後面的表達式必須給出一個屬性的引用,比如
var o = {a:1};
delete o.a; //此處o.a是對象o的屬性a的引用

只有在with語句裡才能使用單獨的屬性名
復制代碼 代碼如下:
with(o){
delete a;
}

二、delete的返回值

delete是普通運算符,會返回true或false。規則為:當被delete的對象的屬性存在並且不能被刪除時 返回false,否則返回true。 這裡的一個特點就是,對象屬性不存在時也返回true,所以返回值並非完全等同於刪除成功與否。
復制代碼 代碼如下:
var o = {a:1};
delete o.a; //返回true
var b = 2;
delete b;//返回false,ECMA規則約定:使用var和function聲明的變量不可以被delete

三、哪些情況下不允許delete

上例提到的var和function聲明的變量不可以被delete,但隱式聲明可以被刪除
復制代碼 代碼如下:
function c(){return 12;}
delete c;//返回false
d = function(){return 12;}
delete d;//返回true

不能delete從原型鏈上繼承的屬性,但可以刪除原型鏈上的屬性
復制代碼 代碼如下:
function Foo(){}
Foo.prototype.bar = 42;
var foo = new Foo();
delete foo.bar; // 返回true,但並沒有起作用
alert(foo.bar); // alerts 42, 屬性是繼承的
delete Foo.prototype.bar; // 在原型上刪除屬性bar
alert(foo.bar); // alerts "undefined", 屬性已經不存在,無法被繼承

四、特例
復制代碼 代碼如下:
eval執行的代碼中如有通過var和function聲明的變量,可以被delete
eval("var a=1");
delete a;
alert(a); //報未定義錯誤

如果聲明是在eval執行代碼中的閉包內進行的,則變量不能被delete
eval("(function(){var a=1;delete a; return a;})()");//1
五、delete 數組元素

從數組中delete其元素並不會影響數組的長度
復制代碼 代碼如下:
var arr = ['yuyin','suhuan','baby'];
delete arr[0];
alert(arr.length);//alert 3

被delete的鍵值已經不屬於數組,但卻還是可以被訪問,其值為undefined。
復制代碼 代碼如下:
var arr = ['yuyin','suhuan','baby'];
delete arr[0];
0 in arr; // false
alert(arr[0]);//undefined
arr[0] === undefined;//true

對比直接將鍵值賦值undefined
復制代碼 代碼如下:
var arr = ['yuyin','suhuan','baby'];
arr[0] = undefined;
0 in arr; // true
alert(arr[0]);//undefined
arr[0] === undefined;//true

可以看出delete 操作只是將鍵值這個屬性從數組中刪除了,數組本身也是對象,這個情況好理解的。如果需要保留鍵值,可以用undefined賦值。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved