2025/1/21 学习Vue的第四天

睡觉。


11.Object.defineProperty

1.在我们之前学习JS的时候,普通得定义一个对象与属性。

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>回顾object.defineProperty方法</title>
</head>
<body>
    <script>
        let Person = {
            name:'张三',
            sex:'男',
            age:18
        }

        console.log(Person)
    </script>
</body>
</html>

我们会发现能够正常输出

2.如果我们想在此写法的对象外面添加属性,应该如何书写?

复制代码
 <!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>回顾object.defineProperty方法</title>
</head>
<body>
    <script>
        let Person = {
            name:'张三',
            sex:'男',
            age:18    
        }

        Object.defineProperty(Person,'address',{
            value:'黄冈'
        })
        console.log(Object.keys(Person))
    </script>
</body>
</html>

打开控制台我们会发现:额外添加的address属性,不能参与遍历

3.得到对象一系列属性的方法是:

复制代码
console.log(Object.keys(Person))

并不能得到address属性

4.让我们试着书写遍历的代码看看能不能遍历得到address。使用for in

复制代码
    for(var key in Person){
            console.log(Person[key])
        }

我们发现并没有得到address的值,这说明我们不能控制额外添加的属性值

那么如何控制额外添加的属性呢?

5.如何控制,使得额外添加属性可修改可遍历可删除

复制代码
   Object.defineProperty(Person,'address',{
            value:'黄冈',
           enumerable:true,//控制属性是否可以枚举
          writable:true,//控制属性是否可以被修改
          configurable:true//控制属性是否可以被删除
        })

6.将额外的属性定义在Object外面,再由Object.defineProperty修改

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>回顾object.defineProperty方法</title>
</head>
<body>
    <script>
        var add ='武汉'
        let Person = {
            name:'李四',
            sex:'男',
            age:18    
        }

        Object.defineProperty(Person,'address',{
        //     value:'黄冈',
        //    enumerable:true,//控制属性是否可以枚举
        //   writable:true,//控制属性是否可以被修改
        //   configurable:true//控制属性是否可以被删除
        get(){
            console.log('有人读取了')
            return add
        },
        set(){
            console.log('有人修改了')
            return add
        }
        })
        // for(var key in Person){
        //     console.log(Person[key])
        // }

        console.log(Person)
        // console.log(Object.keys(Person))

    </script>
</body>
</html>

12.理解数据代理

通过一个对象代理,对另一个对象中属性的操作

1.让我们使用一个简单的例子来实现。

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>理解数据代理</title>
</head>
<body>
    <script>
   let A={
    name1:'苏高阳'
   }
   let B={
    name2:'赵丽颖'
   }
   Object.defineProperty(A,'name2',{
    get(){
        console.log('读取B')
        return B.name2
        },
    set(value){
        console.log('修改A')
        A.name1=value

    }
   })
    </script>
</body>
</html>

2.我们发现通过Object.defineproperty传入一个对象,传入其他对象的属性,可以改变两个对象的属性。

加深了我们对于数据代理的理解。

13.Vue中的数据代理

1.Vue中的数据代理:

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

2.Vue中数据代理的好处:

更加方便的操作data中的数据

3.基本原理:

通过Object.defineProperty()把 data对象中所有属性添加到vm上。

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

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

相关推荐
西岸行者5 天前
学习笔记:SKILLS 能帮助更好的vibe coding
笔记·学习
悠哉悠哉愿意5 天前
【单片机学习笔记】串口、超声波、NE555的同时使用
笔记·单片机·学习
别催小唐敲代码5 天前
嵌入式学习路线
学习
毛小茛5 天前
计算机系统概论——校验码
学习
babe小鑫5 天前
大专经济信息管理专业学习数据分析的必要性
学习·数据挖掘·数据分析
winfreedoms5 天前
ROS2知识大白话
笔记·学习·ros2
在这habit之下5 天前
Linux Virtual Server(LVS)学习总结
linux·学习·lvs
我想我不够好。5 天前
2026.2.25监控学习
学习
im_AMBER5 天前
Leetcode 127 删除有序数组中的重复项 | 删除有序数组中的重复项 II
数据结构·学习·算法·leetcode
CodeJourney_J5 天前
从“Hello World“ 开始 C++
c语言·c++·学习