ホームページ >ウェブフロントエンド >jsチュートリアル >Vue の datepicker プラグインは、datepicker 入力ボックスの値を監視できません。
この記事では、サードパーティの datepicker プラグインを使用するときに Vue が datepicker 入力ボックスの値を監視できない問題の解決策を主に紹介します。興味のある友人はそれを参照できます
1. 背景。
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: '' } }, watch: { dateRange(newVal, oldVal) { console.log(newVal) // 选择日期后无法监听dateRange的改变 } } }
2. 分析
情報を検索すると、Vue が実際には、サードパーティのプラグインによって引き起こされるデータ変更を監視できません。したがって、上記の方法は機能しません。ただし、Vue は、あらゆるデータを Vue で監視できるデータに変換できるメソッド (vm.$set) を提供します。
3. 解決策
私が使用する 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 ) } }
上記は、将来皆さんに役立つことを願っています。
関連記事:
WeChat アプレットで 3 レベルのリンケージ セレクターを使用する方法
PHP クロージャ パッケージと匿名関数 (詳細なチュートリアル)
Vue コンポーネントのカスタム イベントについて (詳細なチュートリアル)
以上がVue の datepicker プラグインは、datepicker 入力ボックスの値を監視できません。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。