當我們使用layui渲染頁面時,由于其采用jQuery的方式,會直接改變DOM結構,這會破壞Vue數據的綁定,導致頁面無法正常的渲染出Vue的數據。
layui.use(['jquery', 'form'], function(){
var $ = layui.jquery,
form = layui.form;
//渲染表單
form.render();
});
由上述代碼可以看出,在layui中渲染表單時,我們調用了form.render()這個函數進行渲染,然而這個渲染是使用了jQuery的方式改變DOM結構的,而Vue數據的綁定是基于DOM結構的,因此會出現渲染出的結果無法正常渲染Vue數據的情況。
Vue提供了一些解決方案,但最簡單的辦法就是使用Vue的watch來監聽頁面渲染的變化,當頁面渲染結束后,觸發watch來手動對DOM結構進行綁定,從而達到更新Vue數據的目的。以下是一個使用watch綁定DOM的示例:
var vm = new Vue({
el: '#app',
data: {
message: 'Hello World!'
},
watch: {
message: function () {
this.$nextTick(function () {
// 渲染完成后執行的代碼
$('#app').html($('#app').html());
});
}
}
})
可以看到,我們在Vue實例的watch中,對message屬性進行監聽,一旦發生變化就通過$nextTick來判斷頁面是否渲染完成,然后手動綁定DOM結構。也就是在DOM的渲染時機變化后通過手動更新必要的視圖。
當然,上述的方案僅僅是解決了layui渲染造成的Vue數據綁定失敗問題的一種辦法,但是對于大型的應用來說,這種方式無疑會增加代碼的復雜度和維護成本。因此在Vue中進行開發的時候,我們要多考慮這方面的問題,對于一些其他的UI框架,也要進行綜合的考慮和評估,以最佳的方案來實現Vue數據的綁定。
上一篇layui和vue比較
下一篇vue中查詢dom