Vue引用第三方datepicker插件无法监听datepicker输入框的值

和自甴很熟 提交于 2020-04-28 08:12:23

<h3>一、背景</h3> <p>在Vue项目中使用了第三方的datepicker插件,在选择日期后vue无法检测到datepicker输入框的变化</p> ``` &lt;label class="fl"&gt;日期:&lt;/label&gt; &lt;div class="input-wrapper fr"&gt; &lt;input class="daterangepicker" ref="datepicker" v-model="dateRange"/&gt; &lt;a href="javascript:;"&gt;&lt;/a&gt; &lt;/div&gt; ```


export default {
    data() {
        return {
            dateRange: ''
        }
    },
    watch: {
        dateRange(newVal, oldVal) {
            console.log(newVal) // 选择日期后无法监听dateRange的改变
        }
    }
}

<h3>二、分析</h3> <p>查找资料发现:Vue实际上无法监听由第三方插件所引起的数据变化。因此上面的方法是行不通的。但是,Vue给我们提供的一个方法,它可以将任意数据转化为可以被Vue监听到的数据,他就是:vm.$set。</p> <h3>三、解决</h3> <p>以我用到的datepicker为例(jquery-daterangepicker)</p>


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 )
      }
    }

原文地址:https://segmentfault.com/a/1190000013012963

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!