通过Object.defineProperty写双向绑定

这里写自定义目录标题

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
        <meta name="viewport"
            content="width=device-width,initial-scale=1,maximum-scale=1,minimum-scale=1,user-scalable=no">
</head>

<body>
    <link rel="icon" href="favicon.ico" type="image x-icon">
    <link rel="shortcut icon" href="favicon.ico" type="image/x-icon">
    <title>微商城</title>
    <script>window.routerBase = "/";</script>
    <div id="app">
        手写一个简单双向绑定<br />
        <div>view:<br/>
        <input id='view' type="text">
        </div>
        <div>model:<br/><span id='model'></span></div>
    </div>
    <script type="text/javascript">
       var obj = {name:'hl'}
       var view = document.querySelector('#view')
       var model = document.querySelector('#model')
       model.innerHTML = obj.name
       view.value = obj.name
       // model => view
       Object.defineProperty(obj,'name',{
           get: function(){
               console.log(this,'获取name')
           },
           set: function(val){
               // 劫持set该对象的name属性,当name变化时,dom相应的也变化,
               model.innerHTML = val
               view.value= val
           }
       })

       // view => model
       view.addEventListener('input',function(e){
        // dom变化时更新model
        obj.name = e.target.value
       })
    
    </script>
</body>

</html>

tip: 可以试试在控制台修改obj.name 的值查看效果
疑问: 为啥get 方法中的this 为空对象,它的name 属性呢?求大佬赐教~~
参照网上其他人写的双向绑定,自动机加了点自己的注释和理解,望斧正


关于上面疑问,查看文档,解释如下:

在这里插入图片描述

so, 由于继承关系,不一定,tip,如果get 方法 return 18,获取obj.name 一直会是18,但是对obj.name 赋值还是会双向绑定,so strange…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值