vue經過 template 來建立你的 HTML。可是,在特殊狀況下,這種寫死的模式沒法知足需求,必須須要js的編程能力。此時,須要用render來建立HTML。javascript
在一次封裝一套通用按鈕組件的工做中,按鈕有四個樣式(default success error )。首先,你可能會想到以下實現html
<div v-if="type === 'success'">success</div>
<div v-else-if="type === 'error'">error</div>
<div v-else-if="type === 'warm'">warm</div>
<div v-else>default</div>
複製代碼
這樣寫在按鈕樣式少的時候徹底沒有問題,可是試想,若是須要的按鈕樣式有十多個,按鈕內的文字根據實際狀況而定(如success按鈕內的文字多是OK、GOOD等等)。那麼template寫死的方式就顯得很無力了。趕上相似這樣的狀況,使用render函數能夠說最優選擇了。vue
首先render函數生成的內容至關於template的內容,故使用render函數時,在.vue文件中須要先把template標籤去掉。只保留邏輯層。java
export default {
render(h) {
return h('div',{
'class': {
btn: true,
success: this.type === 'success',
error: this.type === 'error',
warm: this.type === 'warm',
default: this.type === 'default'
},
domProps: {
innerHTML: this.$slots.default[0].text
},
on: {
click: this.clickHandle
}
})
},
methods: {
clickHandle() {
// dosomething
}
},
props: {
type: {
type: String,
default: 'default'
},
text: {
type: String,
default: 'default'
}
}
};
複製代碼
根據組件化思惟,能抽象出來的東西毫不寫死在邏輯上。這裏的clickHandle函數能夠根據按鈕的type類型觸發不一樣的邏輯,就很少敘述了。編程
而後在父組件調用bash
<btn v-for="(btn, index) in testData" :type="btn.type" :text="btn.text" :key="index">{{btn.text}}
</btn>
複製代碼
是的,要記住每一個參數的類型同用法,按序傳參實在是太麻煩了。那麼其實能夠用jsx來優化這個繁瑣的過程。dom
return (
<div
class={{
btn: true,
success: this.type === 'success',
error: this.type === 'error',
warm: this.type === 'warm',
default: this.type === 'default'
}}
onClick={this.clickHandle}>
{this.$slots.default[0].text}
</div>
)
複製代碼