datepicker插件监听输入框
程序员文章站
2022-04-11 14:04:32
...
这次给大家带来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 ) } }
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
以上就是datepicker插件监听输入框的详细内容,更多请关注其它相关文章!
推荐阅读
-
jquery.hotkeys监听键盘按下事件keydown插件
-
Extjs表单输入框异步校验的插件实现方法
-
jQuery ui 利用 datepicker插件实现开始日期(minDate)和结束日期(maxDate)
-
js与jquery实时监听输入框值的oninput与onpropertychange方法
-
js与jquery实时监听输入框值的oninput与onpropertychange方法
-
A10_DatePicker的对话框设置(使用OnDateSetListener监听器)
-
实时监听input输入框value的变化:
-
js监听input输入框值的实时变化实例
-
推荐三款日期选择插件(My97DatePicker、jquery.datepicker、Mobiscroll)
-
bootstrap datepicker插件默认英文修改为中文