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


Posted in Javascript onJanuary 27, 2018

一、背景

在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 )
   }
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
3款实用的在线JS代码工具(国外)
Mar 15 Javascript
jquery实现checkbox全选全不选的简单实例
Dec 31 Javascript
jQuery实现的Div窗口震动特效
Jun 09 Javascript
node.js实现复制文本到剪切板的功能
Jan 23 Javascript
javascript 中iframe高度自适应(同域)实例详解
May 16 Javascript
基于vue.js快速搭建图书管理平台
Oct 29 Javascript
vue-i18n结合Element-ui的配置方法
May 20 Javascript
浅谈Vue项目骨架屏注入实践
Aug 05 Javascript
扫微信小程序码实现网站登陆实现解析
Aug 20 Javascript
vue实现多级菜单效果
Oct 19 Javascript
详解Vue 数据更新了但页面没有更新的 7 种情况汇总及延伸总结
May 28 Javascript
vue项目中企业微信使用js-sdk时config和agentConfig配置方式详解
Dec 15 Vue.js
浅谈React中组件间抽象
Jan 27 #Javascript
React Native中NavigatorIOS组件的简单使用详解
Jan 27 #Javascript
ejsExcel模板在Vue.js项目中的实际运用
Jan 27 #Javascript
使用D3.js创建物流地图的示例代码
Jan 27 #Javascript
javascript获取图片的top N主色值方法详解
Jan 26 #Javascript
Vue中render方法的使用详解
Jan 26 #Javascript
Angular利用trackBy提升性能的方法
Jan 26 #Javascript
You might like
wordpress之wp-settings.php
2007/08/17 PHP
php自动给文章加关键词链接的函数代码
2012/11/29 PHP
提高php编程效率技巧
2015/08/13 PHP
基于jquery的横向滚动条(滑动条)
2011/02/24 Javascript
JS定时器实例
2013/04/17 Javascript
javascript表格隔行变色加鼠标移入移出及点击效果的方法
2015/04/10 Javascript
浅谈JavaScript中的Math.atan()方法的使用
2015/06/14 Javascript
详解Bootstrap创建表单的三种格式(一)
2016/01/04 Javascript
Vue.js动态组件解析
2016/09/09 Javascript
Centos7 中 Node.js安装简单方法
2016/11/02 Javascript
微信小程序中的swiper组件详解
2017/04/14 Javascript
JS简单实现点击跳转登陆邮箱功能的方法
2017/10/31 Javascript
React BootStrap用户体验框架快速上手
2018/03/06 Javascript
详解Vue2.0配置mint-ui踩过的那些坑
2018/04/23 Javascript
Layui tree 下拉菜单树的实例代码
2019/09/21 Javascript
[16:56]heroes英雄教学 司夜刺客
2014/09/18 DOTA
[03:00]DOTA2-DPC中国联赛1月18日Recap集锦
2021/03/11 DOTA
python数据结构之二叉树的统计与转换实例
2014/04/29 Python
Python中的列表生成式与生成器学习教程
2016/03/13 Python
python Dijkstra算法实现最短路径问题的方法
2019/09/19 Python
详解centos7+django+python3+mysql+阿里云部署项目全流程
2019/11/15 Python
Pycharm中配置远程Docker运行环境的教程图解
2020/06/11 Python
Sublime Text3最新激活注册码分享适用2020最新版 亲测可用
2020/11/12 Python
索引覆盖(Index Covering)查询含义
2012/02/18 面试题
工厂会计员职责
2014/02/06 职场文书
毕业留言寄语大全
2014/04/10 职场文书
出国留学计划书
2014/04/27 职场文书
酒店管理专业自荐信
2014/05/23 职场文书
护士求职信范文
2014/05/24 职场文书
预备党员自我批评思想汇报
2014/10/10 职场文书
维稳工作情况汇报
2014/10/27 职场文书
2015世界地球日活动总结
2015/02/09 职场文书
2015年银行客户经理工作总结
2015/04/01 职场文书
2015年度对口支援工作总结
2015/07/22 职场文书
Oracle安装TNS_ADMIN环境变量设置参考
2021/11/01 Oracle
MySQL实现用逗号进行拼接、以逗号进行分割
2022/12/24 MySQL