本文主要介紹了Vue引用第三方datepicker插件無法監聽datepicker輸入框的值的解決,具有一定的參考價值,有興趣的小伙伴們可以參考一下,希望能幫助到大家。
一、背景
在Vue專案中使用了第三方的datepicker插件,在選擇日期後vue無法偵測到datepicker輸入框的變化
<label class="fl">日期:</label> <p class="input-wrapper fr"> <input class="daterangepicker" ref="datepicker" v-model="dateRange"/> <a href="javascript:;" rel="external nofollow" ></a> </p> export default { data() { return { dateRange: '' } }, watch: { dateRange(newVal, oldVal) { console.log(newVal) // 选择日期后无法监听dateRange的改变 } } }
二、分析
找出資料發現:Vue實際上無法監聽第三方外掛程式所造成的資料變更。因此上面的方法是行不通的。但是,Vue給我們的一個方法,它可以將任意數據轉換為可以被Vue監聽到的數據,他就是:vm.$set。
三、解決
以我用到的datepicker為例(jquery-daterangepicker)
data() { return { date: '', beginDate: '', endDate: '' } }, mounted () { $('.daterangepicker').dateRangePicker({ autoClose: true, format: 'YYYY-MM-DD' }).bind('datepicker-change', this.setDate) //插件自带方法,选择日期后触发回调 }, methods: { setDate() { let datepicker = this.$refs.datepicker //这一步是关键,具体说明可以参见vue api手册 this.$set(this.date, 'beginDate', datepicker.value) this.$set(this.date, 'endDate', datepicker.value) this.beginDate = this.date.beginDate.slice(0, 11) this.endDate = this.date.endDate.slice(-10) } }, watch: { // 这里就可以监听数据变化啦,可以愉快的选择日期了! beginDate(newVal, oldVal) { this.$emit( 'beginDateChange', newVal ) }, endDate(newVal, oldVal) { this.$emit( 'endDateChange', newVal ) } }
相關推薦:
#JS控制項bootstrap datepicker的使用方法(圖)
以上是Vue引用datepicker外掛程式無法監聽datepicker輸入框的值怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!