深入理解vue Render函數(shù)
最近在學習vue,正好今日留個筆記,我自己還在摸索學習中,現(xiàn)整理出來以作記錄。
會使用基本的Render函數(shù)后,就會想,這怎么用 v-for/v-if/v-model;我寫個vue Render函數(shù)進階
首先是v-if 的轉化使用全局組件的v 值決定組件渲染的狀態(tài),對實例中傳遞的props的“nnum”值得控制可以自如的切換兩種狀態(tài)顯示。這樣就是和v-if 一樣使用組件了
<div id="app">
<mycom :v="nnum">
<div slot="slot2">hahahhah</div>
<div slot="slot1">ggggggggggggg</div>
</mycom>
</div>
<script>
Vue.component('mycom',{
render:function(createElement){
var s=this;
if(this.v==1){
return createElement('div',
{
domProps:{innerHTML:'component n='+this.n}
})
}else{
return createElement('div',
[this.$slots.slot1,this.$slots.slot2])
}
},
props:{
v:{
type:Number,
default:0
},
n:{
default:'hello'
}
}
});
var app=new Vue({
el:'#app',
data:{
nnum:1
}
})
v-for 的使用需要需要使用到map
<div id="app">
<mycom :v="nnum" :ar="arr">
<div slot="slot2">hahahhah</div>
<div slot="slot1">ggggggggggggg</div>
</mycom>
</div>
<script>
Vue.component('mycom',{
render:function(createElement){
if(this.v==1){
return createElement('div',
this.ar.map(function(item){
return createElement('li',
{
domProps:{
innerHTML:item
}
})
})
)
}else{
return createElement('div',
[this.$slots.slot1,this.$slots.slot2])
}
},
props:{
v:{
type:Number,
default:0
},
n:{
default:'hello'
},
ar:{
type:Array,
default:function(){ return [1,23,4,5,6,55,65]}
}
}
});
var app=new Vue({
el:'#app',
data:{
nnum:1,
arr:[1,2,3,4,5,6,7,8]
}
})
</script>
</body>
只有map方法才能檢測改變,其他的方法不能根據(jù)數(shù)據(jù)的改變能改變相應的狀態(tài)下的例子中的arr數(shù)組 依靠 apply的方法來實現(xiàn)的就不能夠檢測this.ar 的變換來重新計算
return createElement('div',
Array.apply(null,this.ar.map(function(item){
return createElement('li',
{
domProps:{
innerHTML:'item'
}
})
}))
<body>
<div id="app">
<mycom :v="nnum" :ar="arr">
<div slot="slot2">hahahhah</div>
<div slot="slot1">ggggggggggggg</div>
</mycom>
</div>
<script>
Vue.component('mycom',{
render:function(createElement){
if(this.v==1){
return createElement('div',
this.ar.map(function(item){
return createElement('li',
{
domProps:{
innerHTML:item
}
})
})
)
}else{
return createElement('div',
Array.apply(null,this.ar.map(function(item){
return createElement('li',
{
domProps:{
innerHTML:'item'
}
})
}))
)
}
},
props:{
v:{
type:Number,
default:0
},
n:{
default:'hello'
},
ar:{
type:Array,
default:function(){ return [1,23,4,5,6,55,65]}
}
}
});
var app=new Vue({
el:'#app',
data:{
nnum:2,
arr:[1,2,3,4,5,6,7,8]
}
})
</script>
</body>
v-model 使用domProps來實現(xiàn)雙向綁定
使用對value:賦值可以將數(shù)據(jù)綁定給 input 的默認值,但是對input 的修改并不能傳遞給vue 這涉及到組件的通信問題,
所以想實現(xiàn)雙向綁定,只能自己寫事件來出發(fā) vue shu'j的傳遞
domProps:{value:self.v }
<body>
<div id="app">
<mycom :v="nnum" :ar="arr">
<div slot="slot2">hahahhah</div>
<div slot="slot1">ggggggggggggg</div>
</mycom>
<div>{{nnum}}</div>
</div>
<script>
Vue.component('mycom',{
render:function(createElement){
var self=this;
var inp=createElement('input',
{
domProps:{
value:self.v
}
});
return createElement('div',[inp])
},
props:{
v:{
type:Number,
default:0
},
n:{
default:'hello'
},
ar:{
type:Array,
default:function(){ return [1,23,4,5,6,55,65]}
}
}
});
var app=new Vue({
el:'#app',
data:{
nnum:100,
arr:[1,2,3,4,5,6,7,8]
}
})
</script>
</body>
通過input觸發(fā)undateValue來更新 app中的nnum 值(差點沒轉過彎來,render過于復雜后,真的是自己找罪受)
<div id="app">
<mycom :v="nnum" :ar="arr" @input="updateValue">
</mycom>
<div>{{nnum}}</div>
</div>
<script>
Vue.component('mycom',{
render:function(createElement){
var self=this;
var inp=createElement('input',
{
domProps:{
value:self.v
},
on:{
input:function(event){
self.$emit('input',event.target.value)
}
}
});
return createElement('div',[inp])
},
props:{
v:{
type:Number,
default:0
},
n:{
default:'hello'
},
ar:{
type:Array,
default:function(){ return [1,23,4,5,6,55,65]}
}
},
methods:{
update:function(){
}
}
});
var app=new Vue({
el:'#app',
data:{
nnum:100,
arr:[1,2,3,4,5,6,7,8]
},
methods:{
updateValue:function(value){
this.nnum=parseFloat(value);
}
}
})
</script>
</body>
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
解決vue-router中的query動態(tài)傳參問題
下面小編就為大家分享一篇解決vue-router中的query動態(tài)傳參問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03

