Object.definePeoperty
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>回顾Object.defineProperty</title>
</head>
<body>
<script>
let person={
name:'lhm',
age:23
}
console.log("遍历person");
console.log(Object.keys(person));
// 添加属性
Object.defineProperty(person,"sex",{
value:'女'
})
console.log("遍历person");
console.log(Object.keys(person));
console.log("打印person,颜色暗的不可以被遍历的")
console.log(person)
</script>
</body>
</html>
效果:
data:image/s3,"s3://crabby-images/5c956/5c956b9409a307de99d55f2b5b719791190b730a" alt=""
添加属性
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>回顾Object.defineProperty</title>
</head>
<body>
<script>
let person={
name:'lhm',
age:23
}
console.log("遍历person");
console.log(Object.keys(person));
// 添加属性
let changeSex='男';
Object.defineProperty(person,"sex",{
// value:'女',
// enumerable:true, //可以被枚举,即是遍历
// writeable:true, //可以被修改
// configurable:true, //可以被删除
// 有人读取person.sex时调用
get(){
return changeSex
},
// 有人修改sex属性
set(value){
console.log("有人修改sex属性",value);
changeSex=value;
}
})
console.log("遍历person");
console.log(Object.keys(person));
console.log("打印person,颜色暗的不可以被遍历也不可以修改")
console.log(person)
</script>
</body>
</html>
?data:image/s3,"s3://crabby-images/4c207/4c2074c9edc81d73385beea31d5703cf079b0ded" alt=""
?简单的数据代理例子:
data:image/s3,"s3://crabby-images/80bf5/80bf5f624f806029ce3b886355a4ad0bf1b9a934" alt=""
?Vue中的数据代理
data:image/s3,"s3://crabby-images/7b4b0/7b4b007c8a1eaf945c709cb0953d5d3b0040d533" alt=""
data:image/s3,"s3://crabby-images/8c6ba/8c6ba4f6b77a453b9177dea5ae6a45a38db15f58" alt=""
?
|