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

JS Object.preventExtensions(),Object.seal()與Object.freeze()用法實(shí)例分析

 更新時(shí)間:2018年08月25日 15:29:30   作者:煦涵  
這篇文章主要介紹了JS Object.preventExtensions(),Object.seal()與Object.freeze()用法,結(jié)合實(shí)例形式分析了javascript控制對(duì)象擴(kuò)展、密封、凍結(jié)等相關(guān)函數(shù)與操作技巧,需要的朋友可以參考下

本文實(shí)例講述了JS Object.preventExtensions(),Object.seal()與Object.freeze()用法。分享給大家供大家參考,具體如下:

一、基本介紹

Method Description Param Detail
Object.preventExtensions() 讓一個(gè)對(duì)象變的不可擴(kuò)展,也就是永遠(yuǎn)不能再添加新的屬性 Object 詳細(xì)
Object.isExtensible() 判斷一個(gè)對(duì)象是否是可擴(kuò)展 Object 詳細(xì)
Object.seal() 讓一個(gè)對(duì)象密封,并返回被密封后的對(duì)象。密封對(duì)象是指那些不能添加新的屬性,不能刪除已有屬性,以及不能修改已有屬性的可枚舉性、可配置性、可寫性,但可能可以修改已有屬性的值的對(duì)象。 Object 詳細(xì)
Object.isSealed() 判斷一個(gè)對(duì)象是否是密封的 Object 詳細(xì)
Object.freeze() 凍結(jié)一個(gè)對(duì)象并返回被凍結(jié)的對(duì)象。凍結(jié)對(duì)象是指那些不能添加新的屬性,不能修改已有屬性的值,不能刪除已有屬性,以及不能修改已有屬性的可枚舉性、可配置性、可寫性的對(duì)象。也就是說,這個(gè)對(duì)象永遠(yuǎn)是不可變的。 Object 詳細(xì)
Object.isFrozen() 判斷一個(gè)對(duì)象是否被凍結(jié) Object 詳細(xì)

二、Object.preventExtensions()

Object.preventExtensions 只能阻止一個(gè)對(duì)象不能再添加新的自身屬性,仍然可以為該對(duì)象的原型添加屬性。

2.1 設(shè)置preventExtensions()

var jb51 = {
    name: "zuojj"
};
Object.preventExtensions(jb51);
jb51.url = "http://chabaoo.cn";
//Outputs: undefined
console.log(jb51.url);

2.2 嚴(yán)格模式下使用會(huì)報(bào)錯(cuò)

但是在嚴(yán)格模式下會(huì)報(bào)錯(cuò):

"use strict";
var jb51 = {
    name: "zuojj"
};
Object.preventExtensions(jb51);
jb51.url = "http://chabaoo.cn";
//Outputs: Uncaught TypeError: Can't add property url, object is not extensible
console.log(jb51.url);

2.3 不可以擴(kuò)展屬性,但可以更改已存在屬性值

var jb51 = {
    name: "zuojj"
};
Object.preventExtensions(jb51);
jb51.url = "http://chabaoo.cn";
//Outputs: Uncaught TypeError: Can't add property url, object is not extensible
console.log(jb51.url);

2.4 不能阻止刪除(delete)現(xiàn)有屬性

var jb51 = {
    name: "jb51",
    url : "http://chabaoo.cn"
};
Object.preventExtensions(jb51);
delete jb51.url;
//Outputs: {name: "jb51"}
console.log(jb51);

2.5 使用Object.defineProperty方法為一個(gè)不可擴(kuò)展的對(duì)象添加新屬性會(huì)拋出異常

var jb51 = {
    name: "jb51"
};
Object.preventExtensions(jb51);
jb51 = Object.defineProperty(jb51, "url", {value: "http://chabaoo.cn" });
//Outputs: Uncaught TypeError: Cannot define property:url, object is not extensible.
console.log(jb51);

2.6 判斷一個(gè)對(duì)象是否可擴(kuò)展

var jb51 = {
    name: "jb51",
    url : "http://chabaoo.cn"
};
Object.preventExtensions(jb51);
//Outputs: false
console.log(Object.isExtensible(jb51));

2.7 凍結(jié)對(duì)象和密封的對(duì)象都是不可擴(kuò)展對(duì)象

var jb51 = {
    name: "jb51"
},
sealed = Object.seal(jb51),
frozen = Object.freeze(jb51);
//Outputs: false false
console.log(Object.isExtensible(sealed), Object.isExtensible(frozen));

三、Object.seal()

3.1 不可以添加屬性,但可以修改屬性值

var jb51 = {
    name: "zuojj",
    url: "http://chabaoo.cn"
};
Object.seal(jb51),
jb51.sex = "male";
jb51.name = "jb51";
//Outputs: {name: "jb51", url: "http://chabaoo.cn"}
console.log(jb51);

3.2 嚴(yán)格模式下使用會(huì)報(bào)錯(cuò)

3.3 delete不能刪除現(xiàn)有屬性

var jb51 = {
    name: "jb51",
    url: "http://chabaoo.cn"
};
Object.seal(jb51),
delete jb51.name;
//Outputs: {name: "jb51", url: "http://chabaoo.cn"}
console.log(jb51);

3.4 Object.defineProperty不能擴(kuò)展對(duì)象屬性

var jb51 = {
    name: "jb51",
    url: "http://chabaoo.cn"
};
Object.seal(jb51);
Object.defineProperty(jb51, "sex", {value: "male"})
//Outputs: Uncaught TypeError: Cannot define property:sex, object is not extensible.
console.log(jb51);

上面說到密封對(duì)象不可擴(kuò)展,所以會(huì)報(bào)錯(cuò)

3.5 判斷對(duì)象是否為密封對(duì)象

// 新建的對(duì)象默認(rèn)不是密封的.
var empty = {};
//Outputs: false
console.log(Object.isSealed(empty));
// 空對(duì)象 && 不可擴(kuò)展 === 密封對(duì)象.
Object.preventExtensions(empty);
//Outputs: true
console.log(Object.isSealed(empty));
// 非空對(duì)象 && 不可擴(kuò)展對(duì)象不會(huì)變成密封對(duì)象,因?yàn)槊芊鈱?duì)象的所有自身屬性必須是不可配置的.
var hasProp = { fee: "fie foe fum" };
Object.preventExtensions(hasProp);
//Outputs: false
console.log(Object.isSealed(hasProp));
// 如果把這個(gè)屬性變的不可配置,則這個(gè)對(duì)象也就成了密封對(duì)象.
Object.defineProperty(hasProp, "fee", { configurable: false });
//Outputs: true
console.log(Object.isSealed(hasProp));
console.log("-------------");
// 一個(gè)密封對(duì)象也可以是一個(gè)凍結(jié)對(duì)象,但不是絕對(duì)的.
var s1 = {};
Object.seal(s1);
//Outputs: true
console.log(Object.isFrozen(s1));
var s2 = Object.seal({ p: 3 });
//Outputs: false
console.log(Object.isFrozen(s2)); // 屬性"p"可寫

四、Object.freeze()

4.1 不能添加屬性,且不能修改屬性值

var obj = {
    name: "jb51",
    url: "http://chabaoo.cn"
};
Object.freeze(obj);
obj.sex = "male";
obj.name = "zuojj";
//Outputs: {name: "jb51", url: "http://chabaoo.cn"}
console.log(obj);

4.2 嚴(yán)格模式下使用會(huì)報(bào)錯(cuò)

4.3 delete不能刪除現(xiàn)有屬性

var obj = {
    name: "jb51",
    url: "http://chabaoo.cn"
};
Object.freeze(obj);
delete obj.name;
//Outputs: {name: "jb51", url: "http://chabaoo.cn"}
console.log(obj);

4.4 判斷對(duì)象是否被凍結(jié)

var obj = {
    name: "jb51",
    url: "http://chabaoo.cn"
};
Object.freeze(obj);
//Outputs: true
console.log(Object.isFrozen(obj));

五、兼容性

Object.preventExtensions(),Object.isExtensible(),
Object.seal(),Object.isSealed(),
Object.freeze(),Object.isFrozen()方法是ES5規(guī)范的一部分,IE8及以下低版本瀏覽器不支持。Oprea不支持。

感興趣的朋友還可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具http://tools.jb51.net/code/HtmlJsRun測試運(yùn)行上述js代碼。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論