vue数据绑定原理

简介:
<body>
<h1> {{title}} </h1>
<p> {{title}} </p>
<p> {{num}} </p>

<script>
// var title = "hello";
// var num = 10;
// vue中数据绑定是通过set,get属性实现的,
// 所以不支持es5的浏览器就不能甩vue

// 在组件配置对象中的data中的数据,在组件创建时,都会被作为set,get属性添加到组件对象上,在set方法中进行了组件的重新渲染,所以每当data中的数据发生变化,页面就会立刻重新渲染。
function initAttr (){

let title ;
let num ;
Object . defineProperty ( window , "title" ,{
set ( v ){
title = v ;
render ();
},
get (){
return title ;
}
})

Object . defineProperty ( window , "num" ,{
set ( v ){
num = v ;
render ();
},
get (){
return num ;
}
})
}
initAttr ();
var sourceBody = document . body . innerHTML ;




function render () {
// document.body.innerHTML
let reg = / \{\{ ( \w + ) \}\} / g ;

let content = sourceBody ;

let arr ;
while ( arr = reg . exec ( content )) {
console . log ( arr );
content = content . replace ( arr [ 0 ], window [ arr [ 1 ]])

};
document . body . innerHTML = content ;
// content.replace(reg,)
}
render ();
title = "hello" ;
num = 10 ;

setTimeout (() => {
num = 100 ;
render ();
}, 2000 );
< /script>
</body>
相关文章
|
2天前
|
JavaScript 测试技术
vue不同环境打包环境变量处理
vue不同环境打包环境变量处理
13 0
|
2天前
|
JavaScript
vue中高精度小数问题(加减乘除方法封装)处理
vue中高精度小数问题(加减乘除方法封装)处理
12 0
|
2天前
|
JavaScript
vue项目使用可选链操作符编译报错问题
vue项目使用可选链操作符编译报错问题
6 0
|
2天前
|
JavaScript
Vue项目启动报错处理
Vue项目启动报错处理
6 1
|
2天前
|
JavaScript 定位技术
vue项目开发笔记记录(二)
vue项目开发笔记记录
30 0
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
980 0
|
7天前
|
JavaScript 算法 Linux
【vue报错】error:0308010C:digital envelope routines::unsupported
【vue报错】error:0308010C:digital envelope routines::unsupported
34 3
|
2天前
|
JSON JavaScript API
vue项目开发笔记记录(一)
vue项目开发笔记记录
30 0
|
2天前
|
JavaScript
Vue-实现点击空白处隐藏某节点
Vue-实现点击空白处隐藏某节点
9 1
|
2天前
|
缓存 JavaScript 前端开发
vue项目实战:实战技巧总结(中)
vue项目实战:实战技巧总结
29 1