Object.defineProperty方法结合递归实现数据的可观测性

24 篇文章 0 订阅
15 篇文章 0 订阅
  1. 在js文件中首先要定义一个可观测的class类
  2. 然后使用constructor构造器来定义一个实例
  3. 判断这个数据是个什么类型的数据,并且每个数据类型对应的处理逻辑是什么样的(这里一般只有数组或者对象)
  4. 定义一个可以监测的方法对该数据进行监测
  5. 封装一个Object.defineProperty方法来对数据进行劫持
  6. 判断这个对象的值是不是一个对象,如果是则使用递归调用自身的class类即可
    附上代码:
// 数据可观测类
export class Observer {
    constructor(val) {
        this.val = val
        if (Array.isArray(val)) {
            // 可观测的数据是个数组的逻辑
        } else {
            // 可观测的数据是个对象的逻辑
            this.monitor(val)
        }
    }
    monitor (obj) {
        let keys = Object.keys(obj) //拿到对象中的每个键
        for (let i = 0; i < keys.length; i++) {
            defineReacte(obj, keys[i])
        }
    }
}

// 定义一个可观测的方法
function defineReacte (obj, key, val) {
    if (arguments.length === 2) {
        val = obj[key]
    }
    if (typeof val === 'object') {
        new Observer(val)
    }
    Object.defineProperty(obj, key, {
        get() {
            console.log(`${key}被读取了,值为${val}`);
            return val
        },
        set(newVal) {
            if (val === newVal) {
                return
            }
            val = newVal
            console.log(`${key}被修改了,修改的值为${newVal}`);
        }
    })
}

注意:因为这里使用的是es6的语法写的,所以在htlm页面引用的时候就不能使用常规引用js的方法了,应该在script标签上申明类型是个module,则可以进行import引入

<script type="module">
	  import { Observer } from './_observer.js'
        let obj = new Observer({
            name: '旭陌小生',
            age: 18,
            demo: {
                a: 111
            }
        })
        console.log(obj.val.demo.a);
        obj.val.age = 20
        obj.val.demo.a = 2222
</script >

控制台的输出为:
在这里插入图片描述
所遇到的问题及解决办法:由于chrome新版本的特性,直接打开会报错,原因是跨域所导致的
在这里插入图片描述
解决办法也很简单就是在编辑器中安装一个Live Server的插件,然后在编辑器中的html代码片段中右击鼠标使用Live Server打开就可以了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

旭陌小生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值