<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<div>
{{a.b}}
</div>
<div>
{{c}}
</div>
</div>
<script>
// 判断是不是对象类型
function isObj(x){
if(Object.prototype.toString.call(x) == '[object Object]'){
return true
}
}
function Vue(options){
this._data = options.data
observe(this._data)
// 数据代理
for(let key in this._data){
Object.defineProperty(this,key,{
get(){
return this._data[key]
},
set(newVal){
this._data[key] = newVal
}
})
}
// 模板编译
compile(options.el,this)
}
function observe(data){
for(let key in data){
let val = data[key]
Object.defineProperty(data,key,{
get(){
return val
},
set(newVal){
if(newVal === val){
return
}
val = newVal
if(isObj(newVal)){
observe(newVal)
}
}
})
if(isObj(data[key])){
observe(data[key])
}
}
}
function compile(el,vue){
let dom = document.querySelector(el)
let fragment = document.createDocumentFragment()
while(child = dom.firstChild){
fragment.append(child)
}
let reg = /\{\{(.*)\}\}/
replace(fragment)
function replace(fragment){
Array.from(fragment.childNodes).forEach(node=>{
if(node.nodeType === 3 && reg.test(node.textContent)){
let l = RegExp.$1.split(".")
let val = vue
l.forEach(item=>{
val = val[item]
})
node.textContent = node.textContent.replace(reg,val)
}
if(node.childNodes){
replace(node)
}
})
}
dom.appendChild(fragment)
}
let vue = new Vue({
el:"#app",
data:{a:{b:1},c:2}
})
</script>
</body>
</html>
vue源码分析之模板编译(三)
Vue.js数据绑定与观察者模式
最新推荐文章于 2024-02-11 20:25:19 发布
本文介绍了一个使用Vue.js实现的数据绑定示例,通过观察者模式对数据进行监听和响应式更新。展示了如何创建Vue实例,设置数据属性,并在DOM中使用插值表达式显示数据。
753

被折叠的 条评论
为什么被折叠?



