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

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 14:27:55
字體:
來源:轉載
供稿:網友

一、背景

在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) // 選擇日期后無法監聽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 )   }  }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 怀安县| 喀喇沁旗| 聂拉木县| 康平县| 宣恩县| 天柱县| 县级市| 齐河县| 克拉玛依市| 康乐县| 青河县| 安化县| 临夏县| 西林县| 赤城县| 凯里市| 广水市| 奉贤区| 临朐县| 武强县| 大新县| 酉阳| 武宁县| 白水县| 稷山县| 仁化县| 榆林市| 石阡县| 凤庆县| 阿瓦提县| 乌兰察布市| 杂多县| 隆林| 长寿区| 龙川县| 鲜城| 双辽市| 内江市| 三原县| 南澳县| 建阳市|