vue学习(8)数据代理

简介: vue学习(8)数据代理

场景:比如obj1中存在x,但是我们希望obj2可以访问obj1中的x,同时还可以修改它。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>何为数据代理</title>
</head>

<body>
    <!-- 数据代理:通过一个对象代理对另外一个对象中属性的操作(读、写) -->
    <script type="text/javascript">
        // 比如我们现在希望obj2也能访问到x,并且obj2也能修改x
        let obj1 = {
    x: 100 };
        let obj2 = {
    y: 200 };
        Object.defineProperty(obj2, 'x', {
   
            get() {
   
                return obj1.x;
            },
            set(value) {
   
                obj1.x = value;
            }
        })
    </script>
</body>

</html>

image.png
image.png
知识点:
1:什么是数据代理:通过一个对象代理对另外一个对象中属性的操作(读/写)
2:vue中的数据代理:通过vm对象来代理data对象中属性的操作(读/写)
3:vue中数据代理的好处:更加方便的操作data中的数据。
4:基本原理:
(1)通过obejct.defineproperty()方法把data对象中的属性添加到vm上。
(2)为每一个添加到vm上的属性,都指定一个getter/setter方法。
(3)在getter/setter内部去操作(读/写)data中对应的属性。

目录
相关文章
|
3天前
|
JavaScript 前端开发
Vue项目使用px2rem
Vue项目使用px2rem
|
4天前
|
缓存 JavaScript
vue学习(12)计算属性
vue学习(12)计算属性
15 2
|
3天前
|
JavaScript
Vue组件传值异步问题--子组件拿到数据较慢
Vue组件传值异步问题--子组件拿到数据较慢
8 0
|
3天前
|
缓存 JavaScript
Vue中的keep-alive是什么意思?以及如何使用
Vue中的keep-alive是什么意思?以及如何使用
|
7天前
|
JavaScript
vue学习(3)模板语法
vue学习(3)模板语法
38 11
|
7天前
|
存储 JavaScript 前端开发
vue学习(2)
vue学习(2)
195 65
|
7天前
|
JavaScript 算法 前端开发
vue学习(1)
vue学习(1)
195 62
|
6天前
|
JavaScript
vue学习(4)数据绑定
vue学习(4)数据绑定
19 10
|
6天前
|
JavaScript 前端开发
vue学习(6)
vue学习(6)
23 9
|
6天前
|
JavaScript 开发者
vue学习(5)
vue学习(5)
21 7