本文實例講述了javascript防篡改對象。分享給大家供大家參考,具體如下:
JavaScript中對象內置有多個屬性Configurable,Writable,Enumerable,Value,Get和Set,來控制屬性的行為。同樣的ES5也有幾個方法,來指定對象的行為。我們知道,javascript中的對象是可以共享的,也是默認可拓展的:
//一旦將對象設置防篡改,就不能撤銷了//眾所周知,一般的對象是可以隨意拓展的var person = {name:'liufang'};person.age = 22;document.write(person.age+"<br>");//22我們可以添加、刪除或者修改其他的屬性或者方法。但是這也會導致一些問題,比如多人開發時,某些屬性被人為修改,造成工程上的麻煩。這就促使了防篡改對象的誕生。防篡改對象有三個級別,分別是不可拓展對象、密封對象和凍結對象。
不可拓展對象
先來說說不可拓展對象吧,可以通過就普通對象設置為不可拓展對象,來使新添加的屬性無效:
//防拓展對象Object.preventExtensions(person);//設置為防拓展對象person.smallName = 'ff';document.write(person.smallName+"<br>");//undefined//說明不能添加新屬性//檢測是否為可拓展對象document.write(Object.isExtensible(person)+"<br>");//false//雖然防拓展對象不能添加屬性,但是可以刪除屬性delete person.age;document.write(person.age+"<br>");//undefined ,已經刪除成功
可以看到,雖然不可拓展對象可以防止新添加屬性,卻不能阻止他人刪除屬性,當然也不能阻止修改了。所以引出了第二個等級的密封對象。
密封對象
密封對象就是在不可拓展對象的基礎上添加一條規則,也就是不能刪除屬性。
//密封對象//在不可拓展的基礎上也不能刪除var people = {name:'liufang'};Object.seal(people);//將對象密封delete people.name;document.write(people.name+"<br>");//liufang ,說明不能刪除people.name = "tyq";//雖然不能刪除,但是可以修改document.write(people.name+"<br>");//tyq ,說明修改成功//檢測document.write(Object.isSealed(people)+"<br>");//true可以看出,密封對象雖然防止了刪除,但是還是無法阻止修改,所以就有了最高級別的限制,也就是凍結對象。
凍結對象
被凍結的對象既不能拓展,也不能刪除和修改。
//凍結對象//不能拓展,不能刪除,不能修改var man = {name:'tyq'};Object.freeze(man);//檢測document.write(Object.isFrozen(man));//true最后要注意的就是,一旦對象被設置放篡改對象,則不能撤銷,所以需要慎重考慮。
希望本文所述對大家JavaScript程序設計有所幫助。
新聞熱點
疑難解答