Vue 参照日付ピッカー プラグインが日付ピッカー入力ボックスの値を監視できない場合はどうすればよいですか?

小云云
リリース: 2018-05-23 14:17:01
オリジナル
3107 人が閲覧しました

この記事では、サードパーティの datepicker プラグインを使用するときに Vue が datepicker 入力ボックスの値を監視できない問題の解決策を主に紹介します。興味のある方は参考にしていただければ幸いです。みんな。

1. 背景

サードパーティの日付ピッカー プラグインが Vue プロジェクトで使用されているため、日付を選択した後、Vue は日付ピッカー入力ボックスの変更を検出できません

 <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的改变
    }
  }
}
ログイン後にコピー

2. 分析

情報の検索と検索: Vue は実際には、サードパーティのプラグインによって引き起こされるデータの変更を監視できません。したがって、上記の方法は機能しません。ただし、Vue は、あらゆるデータを Vue で監視できるデータに変換できるメソッド (vm.$set) を提供します。

3. 解決策

私が使用する日付ピッカーを例に挙げます (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 UI 日付ピッカー Datepicker の詳細な説明

JS コントロール ブートストラップの詳細な説明日付ピッカーの使い方 (写真)

php call My97DatePicker_PHP チュートリアル

以上がVue 参照日付ピッカー プラグインが日付ピッカー入力ボックスの値を監視できない場合はどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート