国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Vue引用第三方datepicker插件無法監(jiān)聽datepicker輸入框的值的解決

2024-05-06 15:22:19
字體:
供稿:網(wǎng)友

一、背景

在Vue項目中使用了第三方的datepicker插件,在選擇日期后vue無法檢測到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實際上無法監(jiān)聽由第三方插件所引起的數(shù)據(jù)變化。因此上面的方法是行不通的。但是,Vue給我們提供的一個方法,它可以將任意數(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    //這一步是關鍵,具體說明可以參見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: {  // 這里就可以監(jiān)聽數(shù)據(jù)變化啦,可以愉快的選擇日期了!   beginDate(newVal, oldVal) {     this.$emit( 'beginDateChange', newVal )   },   endDate(newVal, oldVal) {     this.$emit( 'endDateChange', newVal )   }  }

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持錯新站長站。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 松江区| 汾西县| 丹寨县| 永州市| 和硕县| 锦屏县| 观塘区| 延长县| 临邑县| 大余县| 甘孜县| 天镇县| 开江县| 德庆县| 太仆寺旗| 本溪市| 开鲁县| 漠河县| 盖州市| 青神县| 都兰县| 榆树市| 久治县| 宁波市| 石嘴山市| 隆子县| 西昌市| 宁明县| 松溪县| 秦安县| 开江县| 九龙坡区| 龙山县| 亚东县| 镇江市| 唐山市| 湘阴县| 吉林市| 黔西县| 明水县| 连城县|