高防服务器

Vue引用datepicker插件无法监听输入框的值怎么解决


Vue引用datepicker插件无法监听输入框的值怎么解决

发布时间:2022-04-28 17:12:28 来源:高防服务器网 阅读:62 作者:iii 栏目:大数据

这篇“Vue引用datepicker插件无法监听输入框的值怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue引用datepicker插件无法监听输入框的值怎么解决”文章吧。

一、背景

在Vue项目中使用了第三方的datepicker插件,在选择日期后vue无法检测到datepicker输入框的变化

 <label class="fl">日期:</label>   <div class="input-wrapper fr">    <input class="daterangepicker" ref="datepicker" v-model="dateRange"/>    <a href="javascript:;" rel="external nofollow" ></a>   </div>  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 )     }    }

以上就是关于“Vue引用datepicker插件无法监听输入框的值怎么解决”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注高防服务器网行业资讯频道。

[微信提示:高防服务器能助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。

[图文来源于网络,不代表本站立场,如有侵权,请联系高防服务器网删除]
[