zoukankan      html  css  js  c++  java
  • vue回顾Object.defineproperty方法

    1.Object.defineproperty方法中的属性

    value:18 //属性值
    enumerable:true, //控制属性是否可以枚举,默认值是false
    writable:true, //控制属性是否可以被修改,默认值是false
    configurable:true //控制属性是否可以被删除,默认值是false

    2.Object.defineproperty方法的具体使用

    要想在对象中添加对象的属性,可以用 Object.defineproperty 方法

    代码如下:

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8" />
            <title>回顾Object.defineproperty方法</title>
        </head>
        <body>
            <script type="text/javascript" >
                let number = 18
                let person = {
                    name:'张三',
                    sex:'',
                }
    
                Object.defineProperty(person,'age',{
                    value:18,
                    enumerable:true, //控制属性是否可以枚举,默认值是false
                    writable:true, //控制属性是否可以被修改,默认值是false
                    configurable:true //控制属性是否可以被删除,默认值是false
          })
          
                // console.log(Object.keys(person))
                console.log(person)
            </script>
        </body>
    </html>
    1. 设置 enumerable:true 属性后,age属性才会被枚举,也就是可以被遍历

    2. 设置 writable:true 属性后,person.age 属性可以被修改  

    3. 设置 configurable:true 属性后,person.age 属性可以被删除 

    3.Object.defineproperty的getter和setter

    需求:准备好一个数值number,值为18,要求person对象有一个age属性,保存年龄并且年龄是读取number读出来的。

     代码如下:

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8" />
            <title>回顾Object.defineproperty方法</title>
        </head>
        <body>
            <script type="text/javascript" >
                let number = 18
                let person = {
                    name:'张三',
                    sex:'',
                }
    
                Object.defineProperty(person,'age',{
                  //当有人读取person的age属性时,get函数(getter)就会被调用,且返回值就是age的值
                 get(){
                        console.log('有人读取age属性了')
                        return number
                    },
    
                    //当有人修改person的age属性时,set函数(setter)就会被调用,且会收到修改的具体值
                    set(value){
                        console.log('有人修改了age属性,且值是',value)
                        number = value
                    }
          })
          
                // console.log(Object.keys(person))
                console.log(person)
            </script>
        </body>
    </html>

    效果图:

     

  • 相关阅读:
    Linux 4.11 内核变化
    c++设计模式
    【MySQL】undo,redo,2PC,恢复思维导图
    10053
    深入理解MySQL中的Redo、Undo、MVCC
    oracle 博客精选
    Linux内存中的Cache真的能被回收么?
    MySQL性能指标及计算方法 等待show processlist
    HTTP抓包工具Fiddler
    科来网络分析
  • 原文地址:https://www.cnblogs.com/LEPENGYANG/p/15784845.html
Copyright © 2011-2022 走看看