es6数据变更同步到视图层的方法
2019/6/26 23:11:43
本文主要是介绍es6数据变更同步到视图层的方法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
数据变更同步到视图层有一个很重要的东西就是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数据变更同步到视图层的方法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-04package.json 文件位置在哪?-icode9专业技术文章分享
- 2024-10-01Craco.js学习:从入门到实践指南
- 2024-10-01Create-React-App学习:入门与实践指南
- 2024-10-01CSS-in-JS学习:从入门到实践指南
- 2024-09-30JSX语法学习:从入门到初步掌握
- 2024-09-30Mock.js学习:入门教程与实战演练
- 2024-09-30React Hooks学习:从入门到实践
- 2024-09-30受控组件学习:React中的基础入门教程
- 2024-09-29JS定时器教程:初学者必看指南
- 2024-09-29JS对象教程:初学者的全面指南