位置: 编程技术 - 正文

ECMAScript 5中的属性描述符详解(ecmascript新特性)

编辑:rootadmin

推荐整理分享ECMAScript 5中的属性描述符详解(ecmascript新特性),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:ecmascript6简介,ecmascript数据类型,ecmascript9,ecmascript 6,ecmascript6新特性,ecmascript数据类型,ecmascript新特性,ecmascript数据类型,内容如对您有帮助,希望把文章链接给更多的朋友!

属性描述符是ES5中新增的概念,其作用是给对象的属性增加更多的控制。

Object.defineProperty

要研究属性描述符,首先要谈谈 Object.defineProperty 方法。这个方法的作用是给对象定义新属性或修改已存在的属性。其原型如下:使用示例:上面一段代码给obj对象增加了一个名为attr的属性,值为1。相当于:相比起来,Object.defineProperty 的写法看似更为复杂。但是,它最大的奥秘在于其第三个参数。

数据描述符

假设我们希望attr是一个只读属性,就可以加上 writable 数据描述符:执行以上程序可以发现,两次打印出来的attr的值都是1,也就是说对属性的写入失败。然而,这样的结果会有点莫名其妙,因为赋值语句的执行没有异常,却失败了,试想如果在大片的代码中出现这样的问题,就很难排查出来。事实上,只要以严格模式运行代码,就会产生异常:下面再来看看另一个数据描述符 enumerable ,它可以控制属性是否能被枚举。如果只是简单地定义一个属性,这个属性是可以在for...in循环中被枚举出来的:执行上面一段代码,会发现控制台什么也没输出,因为此时attr属性无法被枚举了。

讲到这里,大家可能有一个疑问,属性描述符能否被修改?比方说一个只读属性是否可以再次定义为可写?其实这取决于另一个数据描述符 configurable ,它可以控制属性描述符能否被更改。上面一段代码先把attr定义为只读属性,然后又重新定义为可写。所以对attr的写入是成功的。

ECMAScript 5中的属性描述符详解(ecmascript新特性)

存取描述符

存取描述符类似面向对象中的get/set访问器。在上面一段代码中,对attr的访问事实上变成了对_attr的访问,而且在set函数中限制了最小值为0。

获取属性描述符

前面所述都是设置属性描述符,那如何获取已设置的描述符呢?Object.getOwnPropertyDescriptor 可以完成此项工作。

对象控制

前面说的 Object.defineProperty ,其操作的是对象的属性,而下面说的三个方法则直接操作对象。

Object.preventExtensions 可以使对象无法拥有新的属性:Object.seal 可以使对象仅剩属性值可以修改(如果属性为只读,则连属性值都无法修改):Object.freeze 可以使对象完全无法被修改:然后大家可能又会问,怎么知道某个对象是否曾经被preventExtensions、seal或者freeze呢?答案就是分别调用 Object.isExtensible 、 Object.isSealed 、 Object.isFrozen ,这三个函数的用法比较简单,就不再累赘了。

总的来说,通过属性描述符可以进一步严格控制对象,加强程序逻辑的严谨性,唯一不足的就是,ES5在IE9里面才基本实现(IE9还不支持严格模式),考虑到国内IE8份额还比较高的情况,这套东西目前只能在移动端浏览器和Node.js里面用了。

ECMAScript 5严格模式(Strict Mode)介绍 严格模式(StrictMode)是ECMAScript5的新特性,它允许你把整个程序,或者某个函数,放置在严格的操作语境中。这种严格的语境会防止某些特定的操作并

JavaScript中property和attribute的区别详细介绍 1.定义Property:属性,所有的HTML元素都由HTMLElement类型表示,HTMLElement类型直接继承自Element并添加了一些属性,添加的这些属性分别对应于每个HTML元素都

浅谈JavaScript数据类型 1.数据类型是什么?我们接触的绝大多数程序语言来说,把数据都进行了分类,包括数字、字符、逻辑真假:int,long,string,boolean....等等;我们都知道

标签: ecmascript新特性

本文链接地址:https://www.jiuchutong.com/biancheng/382854.html 转载请保留说明!

上一篇:浅谈JavaScript事件的属性列表

下一篇:ECMAScript 5严格模式(Strict Mode)介绍(严格模式的作用)

  • 国际反避税措施
  • 进项认证以后如何开具红字信息表
  • 公司注销还能要回钱吗
  • 签章是签字还是盖章z还是手印
  • 长期借款科目核算的是企业的长期借款本金和利息
  • 当月进项税额大于销项税额
  • 购买债券取得的利息收入计入什么科目
  • 个税中的其他所得税
  • 劳务费个税申报税率
  • 小规模纳税人开具1%增值税专用发票可以抵扣吗
  • 房地产企业有投资性房地产吗
  • 用现金发工资不给怎么办
  • 防暑降温费如何做账
  • 加计扣除10%进项税政策文件
  • 预借差旅费计入其他应收款吗
  • 简易计税发票如何抵扣
  • 汇算清缴申报表怎么填
  • 公司购买电脑流程怎么做
  • 苹果系统权限管理在哪找
  • 经营性支付与非经营性支付
  • 所得税费用怎么缴纳
  • autorun.exe无法运行
  • 餐费如何入账
  • 史上最贵的微博
  • uniapp控制硬件设备
  • laravel app接口
  • 生产型企业出口退税计算案例
  • 被白雪覆盖的彩虹歌词
  • 增值税发票怎么抵税
  • 资产减值损失和存货跌价准备有什么区别
  • 详解Yii2高级版引入bootstrap.js的一个办法
  • 补缴当年增值税税款和滞纳金如何记账
  • uni.getSystemInfo(OBJECT)
  • 全网最详细的李白解说来了
  • php实现微信支付功能
  • 红字发票账务处理
  • 管理成本分摊比例是多少
  • 应收账款占比高
  • 弥补亏损的会计分录
  • mysql数据库如何回滚
  • mongodb聚合函数mapreduce
  • 以前年度进项转出账务处理
  • 有外币业务需不需要交税
  • 一次性开票分期确认收入如何纳税申报
  • 企业境外投资管理
  • 一般纳税人一直零申报会怎么样
  • 应交税金科目的核算
  • 收到分红的会计科目
  • 预缴增值税需要提供什么资料
  • 发票开具流程是?
  • 有借款合同还要写借条吗
  • 单位收风险金是什么意思
  • 销货清单自己留哪一联
  • 取得无形资产时增值税进项税额的处理
  • 安装生产流水线工程领用原材料
  • 税前扣除的职工福利费怎么算
  • 外贸退税是算利润吗
  • 金蝶主要业务及软件产品
  • 社保个人部分应该做到哪个科目
  • 购入的无形资产加计扣除怎么算
  • 损益平准金是什么会计科目
  • 亏损太多账务如何处理
  • 手工账的做账流程图
  • sqlserver数据备份恢复
  • linux lxd
  • windows 批处理
  • linux 更改目录名
  • windowssystem32configsystem 损坏
  • u盘做pe后还能存储吗
  • react 同级组件之间传值
  • js判断数组是否相等
  • nodejs child_process
  • css兼容性写法
  • nodejs webapp
  • 单例类python
  • python的get
  • 用javascript
  • 简单的移动端项目
  • 中山大学税务硕士
  • 降低税率的坏处
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设