使用代码来简单理解vue2.0和vue3.0的响应式原理

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
<div class="contanier">
<input type="text" id="name" οninput="handleInput(event,this)">
 <input type="text" id="year" οninput="handleInput(event,this)">
 <input type="text" id="age" οninput="handleInput(event,this)">
 <div>
 数据变化如下 vue2.0:
 <span id="vue2"></span>
 </div>
 <div>
 数据变化如下 vue3.0:
  <span id="vue3"></span>
 </div>
</div>
<script>


const obj = observe({
    year:'',
    age:''
},(key,value)=>{
    document.getElementById("vue2").innerHTML = key+":"+value
});

const obj1 = observe2({
    year:'',
    age:''
},(key,value)=>{
    document.getElementById("vue3").innerHTML =key+":"+value
});

function handleInput(e,t){
    if(t.id=="year"){
        obj1.year = e.target.value;
        obj.year = e.target.value
    }
    if(t.id=="age"){
        obj1.age = e.target.value
        obj.age = e.target.value
    }
    if(t.id=="name"){
        obj1.name = e.target.value
    }
}
function observe(obj,callback){
    const newObj = {};
    Object.keys(obj).forEach(key=>{
        Object.defineProperty(newObj,key,{
         configurable:true,
         enumerable:true,
          get (){
             return obj[key];
           },
          set (newVal){
            obj[key]=newVal;
            callback(key,newVal)
          }
         })
    })
   return newObj;
}

function observe2(obj,callback){
    return new Proxy(obj,{
        get:(target,key)=>{
            return targetp[key]
        },
        set:(target,key,value)=>{
          target[key]=value;
          callback(key,value)
        } 
    })
    
    /*return new Proxy(obj,{
    get(target,key){
        return target[key]
    },
    set(target,key,value){
        target[key]=value
        callback(key,value)
    }
})*/
}
</script>
</body>
</html>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值