詳解Vue.js和layui日期控件沖突問題解決辦法
事故還原:
今天在用layui的日期控件的時候發(fā)現(xiàn)一個問題,就是form表單中的日期選擇之后,如果后面的輸入框再輸入值,這個日期就會自動清空,導致沒辦法提交,研究之后發(fā)現(xiàn)是vue的model綁定和layui沖突產(chǎn)生的,事實上是vue無法動態(tài)綁定layui中獲取到的日期值,我們把那個v-model去掉就好,但是去掉的話就沒辦法動態(tài)綁定后臺數(shù)據(jù).
下面是html+vuejs+layui
lyui通過use方法獲取到input的ID實現(xiàn)日期選擇,但是vue的model綁定和layui是有沖突的.
對于這個情況大概處理思路是這樣的:我們就不讓他自動綁定了,把這個input的v-model屬性去掉,然后再form表單提交之前利用jquery手動給這個屬性賦值就好了.
<input type="text" id="beginTime" name="teacherLeave.leaveBegin" v-model="teacherLeave.leaveBegin" class="layui-input">開始時間 <input type="text" name="teacherLeave.reson" v-model="teacherLeave.reson" class="layui-input"> <script> layui.use('laydate', function() { var laydate = layui.laydate; //執(zhí)行一個laydate實例 laydate.render({ elem : '#beginTime' }); }); </script>
下面是具體處理的偽代碼:
//模擬提交方法 saveOrUpdate: function () { //輸出賦值之前的leaveBegin的值,為undefined //vm是vue.js頁面的一個data對象,這部分是vue.js的知識,不用特別在意 alert(vm.teacherLeave.leaveBegin); //通過jquery獲取html頁面input的value值,并將這個值(即時間日期)賦給js中data的vm的teacherLeave屬性 vm.teacherLeave.leaveBegin = $('#beginTime').val(); //輸出賦值之后的leaveBegin的值,作對比 alert(vm.teacherLeave.leaveBegin); //獲取的值不一樣,說明賦值成功 }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解vue2.0監(jiān)聽屬性的使用心得及搭配計算屬性的使用
這篇文章主要介紹了vue2.0之監(jiān)聽屬性的使用心得及搭配計算屬性的使用,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-07-07解決vue項目中出現(xiàn)Invalid Host header的問題
這篇文章主要介紹了解決vue項目中出現(xiàn)"Invalid Host header"的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11基于Vue+elementUI實現(xiàn)動態(tài)表單的校驗功能(根據(jù)條件動態(tài)切換校驗格式)
這篇文章主要介紹了Vue+elementUI的動態(tài)表單的校驗(根據(jù)條件動態(tài)切換校驗格式),本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-04-04vue項目創(chuàng)建并引入餓了么elementUI組件的步驟
這篇文章主要介紹了vue項目創(chuàng)建并引入餓了么elementUI組件的步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-04