Vue引用第三方datepicker插件无法监听datepicker输入框的值的解决

网友投稿 266 2023-02-21


Vue引用第三方datepicker插件无法监听datepicker输入框的值的解决

一、背景

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

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, oldVegqQBPRal) {

this.$emit( 'endDateChange', newVal )

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:spring security 5.x实现兼容多种密码的加密方式
下一篇:23种设计模式(18)java备忘录模式
相关文章

 发表评论

暂时没有评论,来抢沙发吧~