欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

es6数据变更同步到视图层的方法

程序员文章站 2022-08-28 08:12:45
数据变更同步到视图层有一个很重要的东西就是proxy,proxy的作用就是可以隐藏真正的对象,而用户去修改它的代理对象.proxy可以监听数据的变化,例如 <...

数据变更同步到视图层有一个很重要的东西就是proxy,proxy的作用就是可以隐藏真正的对象,而用户去修改它的代理对象.proxy可以监听数据的变化,例如

<div id="test">
  name:{{name}}
  age:{{age}}
</div>
<script>
  let el = document.getelementbyid('test');
  let datainner = {
    name:"jack",
    age:"18"
  }
  let template = el.innerhtml;
  let data = new proxy(datainner,{
    set(obj,name,value){
      console.log(name+"的值被操纵成了value"+value)
      obj[name]=value;
      console.log("数据改变了");
      render()
    }
  })
  data.name="jack chen"
</script>

es6数据变更同步到视图层的方法

es6数据变更同步到视图层的方法

可以监控到data数据的改变,然后就可以将数据渲染到html中,就可以实现es6数据同步到视图层

最终代码

 <script>
  let el = document.getelementbyid('test');
  let datainner = {
    name:"jack",
    age:"18"
  }
  let template = el.innerhtml;
  let data = new proxy(datainner,{
    set(obj,name,value){
      console.log(name+"的值被操纵成了"+value)
      obj[name]=value;
      console.log("数据改变了");
      render();
    }
  })
  render();
  //数据渲染
  function render(){
    el.innerhtml = template.replace(/\{\{\w+\}\}/g,str=>{
      str=str.substring(2,str.length-2);
      console.log(datainner[str]);
      return datainner[str]
    })
  }
</script>

最终效果

es6数据变更同步到视图层的方法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。