首頁 > web前端 > js教程 > 主體

Vue中datepicker外掛程式無法監聽datepicker輸入框的值問題

亚连
發布: 2018-06-09 11:12:56
原創
1853 人瀏覽過

這篇文章主要介紹了Vue引用第三方datepicker外掛無法監聽datepicker輸入框的值的解決,具有一定的參考價值,有興趣的小夥伴們可以參考一下

一、背景

在Vue專案中使用了第三方的datepicker插件,在選擇日期後vue無法偵測到datepicker輸入框的變更

 <label class="fl">日期:</label>
 <p class="input-wrapper fr">
  <input class="daterangepicker" ref="datepicker" v-model="dateRange"/>
  <a href="javascript:;" rel="external nofollow" ></a>
 </p>
export default {
  data() {
    return {
      dateRange: &#39;&#39;
    }
  },
  watch: {
    dateRange(newVal, oldVal) {
      console.log(newVal) // 选择日期后无法监听dateRange的改变
    }
  }
}
登入後複製

#二、分析

尋找資料發現:Vue實際上無法監聽第三方外掛程式所造成的資料變更。因此上面的方法是行不通的。但是,Vue給我們的一個方法,它可以將任意數據轉換為可以被Vue監聽到的數據,他就是:vm.$set。

三、解決

以我用到的datepicker為例(jquery-daterangepicker)

data() {
    return {
      date: &#39;&#39;,
      beginDate: &#39;&#39;,
      endDate: &#39;&#39;
    }
  },
mounted () {
  $(&#39;.daterangepicker&#39;).dateRangePicker({
    autoClose: true,
    format: &#39;YYYY-MM-DD&#39;
  }).bind(&#39;datepicker-change&#39;, this.setDate) //插件自带方法,选择日期后触发回调
 },
methods: {
  setDate() {
    let datepicker = this.$refs.datepicker
    //这一步是关键,具体说明可以参见vue api手册
    this.$set(this.date, &#39;beginDate&#39;, datepicker.value)
    this.$set(this.date, &#39;endDate&#39;, datepicker.value)
    this.beginDate = this.date.beginDate.slice(0, 11)
    this.endDate = this.date.endDate.slice(-10)
  }  
 },
  watch: {
  // 这里就可以监听数据变化啦,可以愉快的选择日期了!
   beginDate(newVal, oldVal) {
     this.$emit( &#39;beginDateChange&#39;, newVal )
   },
   endDate(newVal, oldVal) {
     this.$emit( &#39;endDateChange&#39;, newVal )
   }
  }
登入後複製

上面是我整理給大家的,希望今後會對大家有幫助。

相關文章:

在微信小程式中如何實作圖片預覽功能

使用jquery如何實作手風琴特效

#在微信小程式中如何使用三級連動選擇器

#PHP閉包和匿名函數(詳細教學)

在Vue元件中有關自訂事件(詳細教學)

利用JS如何實作小球跟隨滑鼠移動

以上是Vue中datepicker外掛程式無法監聽datepicker輸入框的值問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!