Vue数据代理

1、概念

通过vm对象来代理data对象中属性的操作(读/写)

2、好处

更方便操作data中的数据

3、基本原理

通过Object.defineProperty()把data中的属性添加到vm中

为每一个添加到vm上的属性,都指定一个getter/setter

在gettter/setter内部去操作(读/写)data中对应的属性

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script type="text/javascript">
        let number = 29
        let person = {
            name: "wt",
            sex: ""
        }
        Object.defineProperty(person, "age", {
            // get()为get:function()简写,执行persion.age 获取该值 
            get(){
                return number
            },
            // set(value)函数为 set:function(value){}简写,设定值
            set(value){
                number = value
            }
        })
    </script>
</body>
</html>
复制代码

 

posted @   市丸银  阅读(7)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示