一、背景

在Vue项目中使用了第三方的datepicker插件,在选择日期后vue无法检测到datepicker输入框的变化

 <label class="fl">日期:</label>
 <div class="input-wrapper fr">
    <input class="daterangepicker" ref="datepicker" v-model="dateRange"/>
    <a href="javascript:;"></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 )
      }
    }

tian0o0
35 声望3 粉丝

这次第,怎一个愁字了得