Vue引用第三方datepicker插件無法監(jiān)聽datepicker輸入框的值的解決
一、背景
在Vue項(xiàng)目中使用了第三方的datepicker插件,在選擇日期后vue無法檢測(cè)到datepicker輸入框的變化
<label class="fl">日期:</label>
<div class="input-wrapper fr">
<input class="daterangepicker" ref="datepicker" v-model="dateRange"/>
<a href="javascript:;" rel="external nofollow" ></a>
</div>
export default {
data() {
return {
dateRange: ''
}
},
watch: {
dateRange(newVal, oldVal) {
console.log(newVal) // 選擇日期后無法監(jiān)聽dateRange的改變
}
}
}
二、分析
查找資料發(fā)現(xiàn):Vue實(shí)際上無法監(jiān)聽由第三方插件所引起的數(shù)據(jù)變化。因此上面的方法是行不通的。但是,Vue給我們提供的一個(gè)方法,它可以將任意數(shù)據(jù)轉(zhuǎn)化為可以被Vue監(jiān)聽到的數(shù)據(jù),他就是:vm.$set。
三、解決
以我用到的datepicker為例(jquery-daterangepicker)
data() {
return {
date: '',
beginDate: '',
endDate: ''
}
},
mounted () {
$('.daterangepicker').dateRangePicker({
autoClose: true,
format: 'YYYY-MM-DD'
}).bind('datepicker-change', this.setDate) //插件自帶方法,選擇日期后觸發(fā)回調(diào)
},
methods: {
setDate() {
let datepicker = this.$refs.datepicker
//這一步是關(guān)鍵,具體說明可以參見vue api手冊(cè)
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: {
// 這里就可以監(jiān)聽數(shù)據(jù)變化啦,可以愉快的選擇日期了!
beginDate(newVal, oldVal) {
this.$emit( 'beginDateChange', newVal )
},
endDate(newVal, oldVal) {
this.$emit( 'endDateChange', newVal )
}
}
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Vue2中Element?DatePicker組件設(shè)置默認(rèn)日期及控制日期范圍
- Element-ui DatePicker顯示周數(shù)的方法示例
- element-ui 限制日期選擇的方法(datepicker)
- vue時(shí)間組件DatePicker組件的手寫示例
- ant design vue datepicker日期選擇器中文化操作
- vue中datepicker的使用教程實(shí)例代碼詳解
- vue項(xiàng)目中引入vue-datepicker插件的詳解
- vue2.0 datepicker使用方法
- 使用Vue寫一個(gè)datepicker的示例
- vue+element?DatePicker實(shí)現(xiàn)日期選擇器封裝
相關(guān)文章
vue實(shí)現(xiàn)圖片路徑轉(zhuǎn)二進(jìn)制文件流(binary)
這篇文章主要介紹了vue實(shí)現(xiàn)圖片路徑轉(zhuǎn)二進(jìn)制文件流(binary),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
vue如何使用mapbox對(duì)當(dāng)前行政區(qū)劃進(jìn)行反選遮罩
這篇文章主要介紹了vue如何使用mapbox對(duì)當(dāng)前行政區(qū)劃進(jìn)行反選遮罩問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
vue車牌號(hào)校驗(yàn)和銀行校驗(yàn)實(shí)戰(zhàn)
這篇文章主要介紹了vue車牌號(hào)校驗(yàn)和銀行校驗(yàn)實(shí)戰(zhàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-01

