vue.js中v-on:textInput无法执行事件问题的解决过程


Posted in Javascript onJuly 12, 2017

前言

最近在学习vue.js框架,学习过程中遇到一些问题,所以记下其中遇到问题的解决过程,避免以后再遇到同样的问题,分享出来也方便遇到这个问题的朋友参考,下面话不多说了,来一起看看详细的介绍:

先来看这段示例代码

<div id="wrap">
  <input type="text" v-on:textInput="fn">
</div>
<script type="text/javascript" src="vue.js"></script>
<script type="text/javascript">
  new Vue({
   el:'#wrap',
   methods:{
    fn:function(){
     console.log('textInput');
    }
   }
  });
</script>

寻找BUG原因步骤

(1)首先通过v-on关键字寻找到 addHandler,此函数传入的事件名竟然是 textinput(正确为textInput,I是大写,而不是小写),错误就定位在这了;然后往上层继续寻找(即父函数)

   注: (onRE.test(name)),var onRE = /^@|^v-on:/;  是通过匹配v-on添加事件

vue.js中v-on:textInput无法执行事件问题的解决过程

(2)processAttrs

vue.js中v-on:textInput无法执行事件问题的解决过程

.....然后傻傻地一层一层往下找,找到了getOuterHTML

vue.js中v-on:textInput无法执行事件问题的解决过程

vue.js中v-on:textInput无法执行事件问题的解决过程

/**
 * Get outerHTML of elements, taking care
 * of SVG elements in IE as well.
 */
function getOuterHTML (el) {
 if (el.outerHTML) {
 return el.outerHTML
 } else {
 var container = document.createElement('div');
 container.appendChild(el.cloneNode(true));
 return container.innerHTML
 }
}

真相大白了,因为vue是利用根原素outerHTML获取里面的dom片段(进行v-on匹配事件监听),然而outerHTML返回转为小写字母的代码片段,导致了textInput转为了 textinput,所以就执行不了;

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
统计出现最多的字符次数的js代码
Dec 03 Javascript
jQuery+css+html实现页面遮罩弹出框
Mar 21 Javascript
JS正则验证邮箱的格式详细介绍
Nov 19 Javascript
js模仿hover的具体实现代码
Dec 30 Javascript
js数字转换为float,取N位小数
Feb 08 Javascript
node.js中的定时器nextTick()和setImmediate()区别分析
Nov 26 Javascript
Angular多选、全选、批量选择操作实例代码
Mar 10 Javascript
JavaScript实现获取用户单击body中所有A标签内容的方法
Jun 05 Javascript
vue中使用vue-router切换页面时滚动条自动滚动到顶部的方法
Nov 28 Javascript
vee-validate vue 2.0自定义表单验证的实例
Aug 28 Javascript
JavaScript链式调用实例浅析
Dec 19 Javascript
Vue作用域插槽实现方法及作用详解
Jul 08 Javascript
详细AngularJs4的图片剪裁组件的实例
Jul 12 #Javascript
JS中使用gulp实现压缩文件及浏览器热加载功能
Jul 12 #Javascript
Vue中的数据监听和数据交互案例解析
Jul 12 #Javascript
js 监控iframe URL的变化实例代码
Jul 12 #Javascript
jQuery 循环遍历改变a标签的href(实例讲解)
Jul 12 #jQuery
浅谈原生JS中的延迟脚本和异步脚本
Jul 12 #Javascript
基于zepto.js实现手机相册功能
Jul 11 #Javascript
You might like
php-beanstalkd消息队列类实例分享
2017/07/19 PHP
php-fpm.conf配置文件中文说明详解及重要参数说明
2018/10/10 PHP
PHP封装的数据库模型Model类完整示例【基于PDO】
2019/03/14 PHP
Javascript基础教程之数据类型 (布尔型 Boolean)
2015/01/18 Javascript
让JavaScript中setTimeout支持链式操作的方法
2015/06/19 Javascript
JS创建事件的三种方法(实例代码)
2016/05/12 Javascript
jQuery控制div实现随滚动条滚动效果
2016/06/07 Javascript
在vue中给列表中的奇数行添加class的实现方法
2018/09/05 Javascript
Vue2.x中利用@font-size引入字体图标报错的解决方法
2018/09/28 Javascript
vue.js实现h5机器人聊天(测试版)
2020/07/16 Javascript
详解微信小程序入门从这里出发(登录注册、开发工具、文件及结构介绍)
2020/07/21 Javascript
Python程序设计入门(2)变量类型简介
2014/06/16 Python
python中__call__方法示例分析
2014/10/11 Python
在树莓派2或树莓派B+上安装Python和OpenCV的教程
2015/03/30 Python
Python基于PycURL自动处理cookie的方法
2015/07/25 Python
Python的Flask框架中SQLAlchemy使用时的乱码问题解决
2015/11/07 Python
python嵌套字典比较值与取值的实现示例
2017/11/03 Python
Python cookbook(数据结构与算法)筛选及提取序列中元素的方法
2018/03/19 Python
python安装pywin32clipboard的操作方法
2019/01/24 Python
Django模型修改及数据迁移实现解析
2019/08/01 Python
Python 内置函数globals()和locals()对比详解
2019/12/23 Python
django rest framework serializer返回时间自动格式化方法
2020/03/31 Python
浅谈keras使用中val_acc和acc值不同步的思考
2020/06/18 Python
详解Python多线程下的list
2020/07/03 Python
Django项目在pycharm新建的步骤方法
2021/03/02 Python
iHerb台湾:维生素、保健品和健康产品
2018/01/31 全球购物
Hawes & Curtis澳大利亚官网:英国经典服饰品牌
2018/10/29 全球购物
The Body Shop美体小铺西班牙官网:天然化妆品
2019/06/21 全球购物
初三政治教学反思
2014/01/30 职场文书
总经理检讨书
2014/09/15 职场文书
铣工实训报告
2014/11/05 职场文书
汽车销售助理岗位职责
2015/04/14 职场文书
2015年车间安全管理工作总结
2015/05/13 职场文书
《葡萄沟》教学反思
2016/02/23 职场文书
导游词之大雁塔景区
2019/09/17 职场文书
MySQL查看表和清空表的常用命令总结
2021/05/26 MySQL