源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2020-11-13 12:21 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:vue.js中v-on:textInput无法执行事件问题的解决过程
[b]前言[/b] 最近在学习vue.js框架,学习过程中遇到一些问题,所以记下其中遇到问题的解决过程,避免以后再遇到同样的问题,分享出来也方便遇到这个问题的朋友参考,下面话不多说了,来一起看看详细的介绍: [b]先来看这段示例代码[/b]
<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>
[b]寻找BUG原因步骤[/b] (1)首先通过v-on关键字寻找到 addHandler,此函数传入的事件名竟然是 textinput(正确为textInput,I是大写,而不是小写),错误就定位在这了;然后往上层继续寻找(即父函数)    [b]注: [/b][code](onRE.test(name)),var onRE = /^@|^v-on:/;[/code]  是通过匹配v-on添加事件 [img]http://files.jb51.net/file_images/article/201707/201771292303313.png?201761292310[/img] (2)processAttrs [img]http://files.jb51.net/file_images/article/201707/201771292330386.png?201761292337[/img] .....然后傻傻地一层一层往下找,找到了getOuterHTML [img]http://files.jb51.net/file_images/article/201707/201771292352212.png?201761292359[/img] [img]http://files.jb51.net/file_images/article/201707/201771292407516.png?201761292416[/img]
/**
 * 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,所以就执行不了; [b]总结[/b] 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程素材网的支持。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部