zoukankan      html  css  js  c++  java
  • JavaScript对象

    javascript 对象
    1、数据属性:
    [[Configurable]] 表示是否能通过delete删除属性从而又一次定义属性,是否能改动属性的特性,或者是否能把属性改动为訪问器属性。直接在对象上定义的属性,它们的默认值为true
    [[Enumberable]] 表示是否能通过for-in 循环返回属性。直接在对象上定义的属性,它们的这个特性默认值为true
    [[Writable]] 表示是否能改动属性的值。直接在对象上定义的属性,他们的这个特性默认值为true
    [[Value]] 包括这个属性的数据值。 读取属性值的时候,从这个位置读; 写入属性值的时候,把新值保存在这个位置。这个特性的默认值为undefined
    var person={};
    Object.defineProperty(person, "name", {
    writable: false,
    value: "Bruce"
    });


    alert(person.name);  //Bruce
    person.name = "Bao";
    alert(person.name);  //Bruce


    这个样例创建一个名为name的属性,它的值"Bruce"是仅仅读的。这个属性的值是不可改动的,假设尝试为它指定新值,则在非严格模式下,赋值操作将会导致抛出错误。
    类似的规则也适用于不可配置的属性。比如:
    var person = {};
    Object.defineProperty(person, "name", {
    configurable:false,
    value: "Bruce"
    })


    alert(person.name);   //Bruce
    delete person.name;
    alert(person.name);   //Bruce
    把configurable 设置为false, 表示不能从对象中删除属性。假设对这个属性进行调用delete, 则在非严格模式下什么也不会发生,而在严格模式下会导致错误。并且,一旦把属性定义为不可配置的,就不能再把它变回可配置了。此时,再调用Object.defineProperty()方法改动除writable之外的特性,都会导致错误:
    var person = ();
    Object.defineProperty(person, "name",{
    configurable: false,
    value: "Bruce"
    });


    //抛出错误
    Object.defineProperty(person, "name", {
    configurable: true,
    value: "Bruce"
    });


    也就是说能够多次调用Object.defineProperty()方法改动允许属性,但在把configurable特性设置为false之后就会有限制了。
    在调用Object.defineProperty()方法时,假设不指定,configurable、enumberable、和writable特性默认值都是false。多数情况下,可能没有必要利用Object.defineProperty()方法提供这些高级功能。只是,理解这些概念对理解JavaScript对象却很实用。
  • 相关阅读:
    python unittest--TestSuit类--通过unittest.TestSuite()类直接构建,或者通过TestSuite实例的addTests、addTest方法构建
    Cannot read property 'toLowerCase' of undefined
    Vue 中登录功能的简单实现
    git 常用命令
    js 锚点定位的简单方法
    Vue element-ui 使用Loading服务按需引入的坑
    防抖 节流
    element-ui 日期选择器-开始结束日期选择限制
    vue elment-ui 对navTab导航组件封装
    vue 监听窗口变化对页面部分元素重新渲染
  • 原文地址:https://www.cnblogs.com/yxwkf/p/3860563.html
Copyright © 2011-2022 走看看