您好,欢迎来到五一七教育网。
搜索
您的当前位置:首页Vue中datepicker插件无法监听datepicker输入框的值问题

Vue中datepicker插件无法监听datepicker输入框的值问题

来源:五一七教育网


这篇文章主要介绍了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: ''
 }
 },
 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 )
 }
 }

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在微信小程序中如何实现图片预览功能

使用jquery如何实现手风琴特效

在微信小程序中如何使用三级联动选择器

PHP闭包和匿名函数(详细教程)

在Vue组件中有关自定义事件(详细教程)

利用JS如何实现小球跟随鼠标移动

Copyright © 2019- 517ttc.cn 版权所有 赣ICP备2024042791号-8

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务