JavaScript

超轻量级php框架startmvc

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

更新时间:2020-08-16 13:18:01 作者:startmvc
数据变更同步到视图层有一个很重要的东西就是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>

可以监控到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 数据变更 es6数据变更到视图层