vue.js中v-on:textInput无法执行事件问题的解决过程
程序员文章站
2022-05-26 08:28:18
前言
最近在学习vue.js框架,学习过程中遇到一些问题,所以记下其中遇到问题的解决过程,避免以后再遇到同样的问题,分享出来也方便遇到这个问题的朋友参考,下面话不多说了,...
前言
最近在学习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添加事件
(2)processattrs
.....然后傻傻地一层一层往下找,找到了getouterhtml
/** * 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,所以就执行不了;
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
下一篇: 网页中的图片查看器viewjs使用方法