最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

datepicker插件监听输入框

来源:动视网 责编:小采 时间:2020-11-27 19:58:32
文档

datepicker插件监听输入框

datepicker插件监听输入框:这次给大家带来datepicker插件监听输入框,datepicker插件监听输入框的注意事项有哪些,下面就是实战案例,一起来看一下。一、背景在Vue项目中使用了第三方的datepicker插件,在选择日期后vue无法检测到datepicker输入框的变化 <label cla
推荐度:
导读datepicker插件监听输入框:这次给大家带来datepicker插件监听输入框,datepicker插件监听输入框的注意事项有哪些,下面就是实战案例,一起来看一下。一、背景在Vue项目中使用了第三方的datepicker插件,在选择日期后vue无法检测到datepicker输入框的变化 <label cla


这次给大家带来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 )
 }
 }

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

JS获取图片的top N色值方法

使用render方法的图文详解

文档

datepicker插件监听输入框

datepicker插件监听输入框:这次给大家带来datepicker插件监听输入框,datepicker插件监听输入框的注意事项有哪些,下面就是实战案例,一起来看一下。一、背景在Vue项目中使用了第三方的datepicker插件,在选择日期后vue无法检测到datepicker输入框的变化 <label cla
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top