js之oop <四>对象管理

对象扩展管理

Object.isExtensible() 检测对象是否可扩展(一般返回true)。
Object.preventExtensions() 防止对象扩展。

var p = {p1:"a",p1:"b"};
Object.isExtensible(p);     //返回true
Object.preventExtensions(p);    //防止对象扩展
Object.isExtensible(p);     //返回false

对象可扩展情况下,则可以添加属性。若不可扩展,则不能添加属性。

var p = {p1:"a",p1:"b"};
p.p3 = "new_element";
p.p3;   //输出new_element
Object.preventExtensions(p);    //防止对象扩展
p.p4 = "new_extensible";    //添加属性失败
p.p4;   //输出undefined

但防止扩展,对象原有属性的属性标签仍都是true。

var p = {p1:"a",p1:"b"};
Object.preventExtensions(p);
Object.getOwnPropertyDescriptor(p,"p1");
//返回 { value: ‘b‘, writable: true,  enumerable: true,  configurable: true }

这意味着原有属性可被删除,修改。

var p = {p1:"a",p1:"b"};
Object.preventExtensions(p);
delete p.p1;        //返回true 且p.p1输出undefined

***************************************************************************************************************

对象密封管理

Object.isSealed() 检测对象是否密封(一般返回false)。
Object.seal() 密封对象。

var o = { o1:1,o2:2 };
Object.seal(o); //密封对象
o.o3 = 3;       //赋值不成功 o.o3返回undefined
o.o1 = 81;      //o.o1返回81 修改成功
delete o.o1;    //返回false 删除不成功
Object.getOwnPropertyDescriptor(o,"o1");
//返回{ value: 1,writable: true,enumerable: true,configurable: false } 

对象设置seal后,对象除了禁止扩展,且对象所有属性的configurable都为false。

***************************************************************************************************************

对象冻结管理

Object.isFrozen() 检测对象是否冻结(一般返回false)。
Object.Freeze() 冻结对象。

var q = { q1:1,q2:2 };
Object.freeze(q);   //冻结对象
q.q3 = 3;           //赋值不成功 o.o3返回undefined
q.q2 = 100;         //q.q2返回2  修改失败
delete q.q2;        //返回false 删除不成功
Object.getOwnPropertyDescriptor(q,"q2");
//返回{ value: 2,writable: false,enumerable: true,configurable: false }

对象设置freeze后,对象除了被密封,且对象所有属性的writable属性都为false。

时间: 2024-08-08 19:28:06

js之oop <四>对象管理的相关文章

js之oop &lt;五&gt;对象序列化

js对象序列化的过程,就是对象转换为JSON的过程.JSON.stringify() 将对象序列化成JSON.(接收对象,输出字符串) var obj = {x:2,y:3}; var str = JSON.stringify(obj); //输出 {"x":2,"y":3} 序列化时,对象的函数序列化时不会显示. var obj = {a:1,b:2,c:function(){ console.log(3); }}; var str = JSON.stringif

js之oop &lt;二&gt; 对象属性

js中对象属性可以动态添加和删除.删除对象属性用delete关键字. function obj(){ } var oo = new obj(); oo.a = "a"; oo.b = "b"; oo.a; //输出a oo.b; //输出b delete oo.a; oo.a; //输出undefined 在js中对象的属性以键值对的方式来体现,且(在遍历时)无序.js中属性名(也就是key)可以用点来访问(或赋值),也可以用中括号key值来访问(或赋值)(用中括号

【高德地图API】从零开始学高德JS API(四)搜索服务——POI搜索|自动完成|输入提示|行政区域|交叉路口|自有数据检索

摘要: 地图服务,大家能想到哪些?POI搜素,输入提示,地址解析,公交导航,驾车导航,步行导航,道路查询(交叉口),行政区划等等.如果说覆盖物Marker是地图的骨骼,那么服务,就是地图的气血.有个各种各样的地图服务,我们的地图应用才能变得有血有肉,活灵活现. 第四篇拆成了几个要点,本篇主要讲搜索服务.包括周边搜索,关键词搜索,范围搜索,搜索提示(自动完成,输入提示),行政区域,交叉路口,检索自有数据(云图). demo:http://zhaoziang.com/amap/zero_4_1.ht

【高德地图API】从零开始学高德JS API(四)搜索服务

摘要:地图服务,大家能想到哪些?POI搜素,输入提示,地址解析,公交导航,驾车导航,步行导航,道路查询(交叉口),行政区划等等.如果说覆盖物Marker是地图的骨骼,那么服务,就是地图的气血.有个各种各样的地图服务,我们的地图应用才能变得有血有肉,活灵活现.第四篇拆成了几个要点,本篇主要讲搜索服务.包括周边搜索,关键词搜索,范围搜索,搜索提示(自动完成,输入提示),行政区域,交叉路口,检索自有数据(云图). demo:http://zhaoziang.com/amap/zero_4_1.html

Oracle学习(十四):管理用户安全

--用户(user) SQL> --创建名叫 grace 密码是password 的用户,新用户没有任何权限 SQL> create user grace identified by password; 验证用户: 密码验证方式(用户名/密码) 外部验证方式(主机认证,即通过登陆的用户名) 全局验证方式(其他方式:生物认证方式.token方式) 优先级顺序:外部验证>密码验证 --权限(privilege) 用户权限有两种: System:允许用户执行对于数据库的特定行为,例如:创建表.

拖拽系列二、利用JS面向对象OOP思想实现拖拽封装

接着上一篇拖拽系列一.JavaScript实现简单的拖拽效果这一篇博客将接着对上一节实现代码利用JS面向对象(OOP)思维对上一节代码进行封装; 使其模块化.避免全局函数污染.方便后期维护和调用:写到这里突然想起一句话“没有任何一个题目是彻底完成的.总还会有很多事情可做......” 我想这句话程序开发大概也适用吧,前端开发人员总是可以结合自己之前学到“拖拽”相关知识,不断扩展.完善.无穷无尽.......     利用匿名函数自执行实现封装 ;(function(){ //do somethi

Oracle442个应用场景----------数据库逻辑对象管理

-----------------数据库逻辑对象管理-------------------- ORACLE基本数据类型(亦叫内置数据类型 built-in datatypes)可以按类型分为:字符串类型.数字类型.日期类型.LOB类型.LONG RAW& RAW类型.ROWID & UROWID类型. 在讲叙字符串类型前,先要讲一下编码.字符串类型的数据可依编码方式分成数据库字符集(CHAR/VARCHAR2/CLOB/LONG)和国际字符集(NCHAR/NVARCHAR2/NCLOB)两

C++ 类的对象管理模型初讲

//类的对象管理模型初讲 #include<iostream> using namespace std; class PointA{ private: int x;//占据4个字节大小的内存空间 int y;//占据4个字节大小的内存空间 int z;//占据4个字节大小的内存空间 };//总共占据12个字节 class PointB{ public: PointB(int _x, int _y,int _z){ x = _x; y = _y; z = _z; } void GetX(){ c

js中的json对象详细介绍

JSON一种简单的数据格式,比xml更轻巧,在JavaScript中处理JSON数据不需要任何特殊的API或工具包,下面为大家详细介绍下js中的json对象, 1.JSON(JavaScript Object Notation)一种简单的数据格式,比xml更轻巧.JSON是JavaScript原生格式,这意味着在JavaScript中处理JSON数据不需要任何特殊的API或工具包. JSON的规则很简单:对象是一个无序的“‘名称:值'对”集合.一个对象以“{”(左括号)开始,“}”(右括号)结束