object.definepProperty使用方法,vue2双向绑定原理

首先要介绍的是definepProperty的三个参数

javascript 复制代码
object.definepProperty(对象名,属性名,属性值)

再者要介绍的就是属性值了,

javascript 复制代码
object.definepProperty(person,age,{value:18})

此时我们会遇到如下几个问题

一、第一,我们添加的这个属性名,不可被枚举

javascript 复制代码
object.definepProperty(person,age,{value:18})

object.keys(person)

for(var item in person){
    console.log(item)
}

解决方法:

我们为其添加可枚举属性。enumerable:true,默认值是false

javascript 复制代码
Object.defineProperty(obj, 'age', {
  value: "18",
  enumerable: true
});

二、第二,我们添加的这个属性名,不可被修改

javascript 复制代码
object.definepProperty(person,age,{
value:18
enumerable:true
})

person.age =20

解决方法:添加writeable:true(可以被修改)属性,默认值false(不可被修改)

javascript 复制代码
object.definepProperty(person,age,{
value:18,
enumerable:true, //控制属性是否可以枚举,默认值是false
writeable:true // 控制属性是否可以被修改,默认值是false
})

person.age =20

三、第三,我们添加的这个属性名,不可被删除

javascript 复制代码
object.definepProperty(person,age,{
value:18,
enumerable:true, //控制属性是否可以枚举,默认值是false
writeable:true // 控制属性是否可以被修改,默认值是false
})

delete person.age 
//或者
delete person['age']

解决方法:添加configurable:true(可以被删除),默认值false(不可被删除)

javascript 复制代码
Object.defineProperty(person.age,{
value:18,
enumerable:true, //控制属性是否可以被枚举,默认值false
writerable:true,  // 控制属性是否可以被修改,默认值false
configrable:true //控制属性是否可以被删除,默认值false
})

四、get(gtter)和set(setter)用法

1.当要将另一个变量的值number赋值给age时候,当改变number的值的时候,对象中age的值并没有发生改变

javascript 复制代码
number=10

person={
age:number
}
// {age:10}

number =12

//{age:10}

解决,此时我们就要用到get()函数来实现,get的返回值,就是age的值

get():当有人读取person的age属性时,就会调用get()方法,此时number现在的值就会赋值给age

javascript 复制代码
object.definepProperty(person,age,{
    get(){
        return number
    }
})

2.当有人给age赋值时候,但是age的值没有改变,这是因为age的值是number

javascript 复制代码
var number =10

person={
    age:number
}
person.age =20
// {age:10}

解决方法:使用set()函数,获取到age改变的值,然后赋值给number

set():当有人改变age 的时候,获取到改变的值,赋值给number,此时我们再次获取age时候,就会调用get()把number的值赋值给age

javascript 复制代码
object.definepProperty(person,age,{
    // 当有人获取age时候,就会调用get()
    get(){
        return number
    },
    //当有人改变age的时候,就会调用set()
    set(value){
    number = value
}
})
相关推荐
dy171723 分钟前
element-plus表格默认展开有子的数据
前端·javascript·vue.js
CodeCraft Studio3 小时前
PDF处理控件Aspose.PDF教程:使用 Python 将 PDF 转换为 Base64
开发语言·python·pdf·base64·aspose·aspose.pdf
零点零一3 小时前
VS+QT的编程开发工作:关于QT VS tools的使用 qt的官方帮助
开发语言·qt
2501_915918414 小时前
Web 前端可视化开发工具对比 低代码平台、可视化搭建工具、前端可视化编辑器与在线可视化开发环境的实战分析
前端·低代码·ios·小程序·uni-app·编辑器·iphone
程序员的世界你不懂5 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
索迪迈科技5 小时前
网络请求库——Axios库深度解析
前端·网络·vue.js·北京百思可瑞教育·百思可瑞教育
gnip5 小时前
JavaScript二叉树相关概念
前端
lingchen19065 小时前
MATLAB的数值计算(三)曲线拟合与插值
开发语言·matlab
gb42152875 小时前
java中将租户ID包装为JSQLParser的StringValue表达式对象,JSQLParser指的是?
java·开发语言·python
一朵梨花压海棠go5 小时前
html+js实现表格本地筛选
开发语言·javascript·html·ecmascript