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

JavaScript 防篡改對象的用法示例

 更新時間:2021年04月23日 17:12:34   作者:德萊問  
這篇文章主要介紹了JavaScript 防篡改對象的用法示例,幫助大家更好的理解和學習使用JavaScript,感興趣的朋友可以參考下

javascript防篡改對象

這個東西吧,用到的很少,個人感覺用處不大,但是,可以作為裝逼的利器,哈哈,開搞。。

1、不可擴展對象

默認情況下對象都是可以擴展的,也就是說,任何時候都可以向?qū)ο笾刑砑訉傩院头椒ā,F(xiàn)在使用Object.preventExtensions(object)方法可以改變這個行為,讓你不能再給對象添加屬性和方法。例如:

var person={name : 'jack'};
Object.preventExtensions(person);
person.age=13;
console.log(person.age);///undefine

雖然不能給對象添加新成員,但是已有的成員則絲毫不受影響,你仍然可以修改和刪除自己的已有的成員。另外使用isExtensible()方法還可以確定對象是否可以擴展。例如:

var person={name : 'jack'};
alert(Object.isExtensible(person));//true

Object.preventExtensions(person);
alert(Object.istExtensible(person));//false

2、密封的對象

ECMAScript 5 為對象定義的第二個保護級別是密封對象。使用Object.seal(object)方法可以將對象改為密封對象。密封對象不可擴展,而且已有成員的[[configurable]]特性將被設置為false。這就意味著不能刪除屬性和方法,因為不能使用Object.defineProperty()把數(shù)據(jù)修改為訪問其屬性,或者相反。但是屬性值是可以修改的。

var person = {name:'tom'};
Object.seal(person);
person.age=12;
console.log(person.age);//undefine

delete person.name;
console.log(person.name);//tom

person.name="jack";
alert(person.name);//jack

使用Object.isSealed()方法可以確定對象是否被密封了,因為被密封的對象也是不可擴展的,所以使用Object.istExtensible()檢測密封對象也會返回false(即不可擴展)

var person = {name:'tom'};
alert(Object.isExtensible(person));///true,可擴展
alert(Object.isSealed(person));////false,未加密
               
Object.seal(person);
alert(Object.isExtensible(person));///false,不可擴展
alert(Object.isSealed(person));////true,已經(jīng)加密

3、凍結(jié)的對象

最嚴格的的防止篡改級別的是凍結(jié)對象,凍結(jié)的對象既不可擴展,又是密封的,而且對象的數(shù)據(jù)屬性的[[Writable]]特性會被設置為false,如果定義set函數(shù),訪問器屬性仍然是可寫的,現(xiàn)在使用Object.freeze(object)方法可以將對象改為凍結(jié)的對象。

var person={name : 'tony'};
Object.freeze(person);
person.age=12;
alert(person.age);//undefine

delete person.name;
alert(person.name);//tony

person.name = 'jack';
alert(person.name);//tony

使用Object.isFrozen()方法可以檢測對象是否是凍結(jié)對象,因為凍結(jié)對象既是不可擴展對象,又是密封的對象,所以用isExtensible()
和Object.istExtensible()檢測凍結(jié)對象將分別返回false和true,

var person = {name:'tom'};
alert(Object.isExtensible(person));///true,可擴展
alert(Object.isSealed(person));////false,未加密
alert(Object.isFrozen(person));////false,未加密
               
Object.seal(person);
alert(Object.isExtensible(person));///false,不可擴展
alert(Object.isSealed(person));////true,已經(jīng)加密
alert(Object.isFrozen(person));////true,已經(jīng)凍結(jié)

以上就是JavaScript 防篡改對象的用法示例的詳細內(nèi)容,更多關于JavaScript 防篡改對象的資料請關注腳本之家其它相關文章!

相關文章

  • 利用Three.js實現(xiàn)3D三棱錐立體特效

    利用Three.js實現(xiàn)3D三棱錐立體特效

    Three.js是基于原生WebGL封裝運行的三維引擎,在所有WebGL引擎中,Three.js是國內(nèi)文資料最多、使用最廣泛的三維引擎。本文將用Three.js實現(xiàn)3D三棱錐立體特效,感興趣的可以了解一下
    2022-06-06
  • createElement和onclick

    createElement和onclick

    createElement和onclick...
    2006-11-11
  • JavaScript中淺講ajax圖文詳解

    JavaScript中淺講ajax圖文詳解

    ajax對于各位來說,應該都不陌生,正因為ajax的產(chǎn)生,導致前臺頁面和服務器之間的數(shù)據(jù)傳輸變得非常容易,同時還可以實現(xiàn)頁面的局部刷新。本文圖文并茂給大家介紹了js中ajax知識,需要的朋友一起學習吧
    2016-11-11
  • javascript實現(xiàn)切換td中的值

    javascript實現(xiàn)切換td中的值

    這篇文章主要介紹了javascript實現(xiàn)切換td中的值的方法,需要的朋友可以參考下
    2014-12-12
  • css樣式標簽和js語法屬性區(qū)別

    css樣式標簽和js語法屬性區(qū)別

    css樣式標簽和js語法屬性區(qū)別。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-11-11
  • JavaScript計算出現(xiàn)精度丟失問題的解決方法

    JavaScript計算出現(xiàn)精度丟失問題的解決方法

    Javascript作為一門大型編程語言,在日常開發(fā)中難免會涉及到大量的數(shù)學計算,然而,浮點數(shù)在計算過程中可能出現(xiàn)精度的問題,下面我們就來學習一下Javascript中高精度計算及其相關知識吧
    2023-11-11
  • javascript常用代碼段搜集

    javascript常用代碼段搜集

    這篇文章主要記錄了本人搜集的幾段javascript常用代碼段,都是平時項目中需要用到的,需要的朋友可以參考下
    2014-12-12
  • 深入解析ECMAScript?2023?中的新數(shù)組方法

    深入解析ECMAScript?2023?中的新數(shù)組方法

    ECMAScript?是一種標準化的腳本語言,它是?JavaScript?的規(guī)范。ECMAScript?2023?是?JavaScript?編程語言的更新,旨在帶來改進并使?JavaScript?程序可預測和可維護,這篇文章主要介紹了探索?ECMAScript?2023?中的新數(shù)組方法,需要的朋友可以參考下
    2023-12-12
  • 網(wǎng)易首頁的新聞代碼

    網(wǎng)易首頁的新聞代碼

    網(wǎng)易首頁的新聞代碼...
    2007-01-01
  • 打豆豆小游戲 用javascript編寫的[打豆豆]小游戲

    打豆豆小游戲 用javascript編寫的[打豆豆]小游戲

    用javascript 寫了一個打豆豆的游戲,至于怎么玩的就不細說了,到網(wǎng)上搜一下就知道了,很簡單,感興趣的朋友可以了解下哦
    2013-01-01

最新評論