这篇文章主要介绍了详解关于element el-button使用$attrs的一个注意要点,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
之前需要对 el-button
做二次封装,所以就用到 vue
的 $attrs
和 $listeners
属性,这两个属性在这不细说,可以在这里 查看详情。
二次封装代码(limit-button)
这样封装的好处就是不需要将上层每个属性都写一次 prop
定义,对 listeners
也不需要做一层中转 emit
。
发现问题
在某个页面,点击经过封装的 limit-button
会使页面进行刷新
起初以为是点击事件的冒泡产生的,就把上层引用的 @click
去掉:
点击
发现还是一样会产生刷新的事件。
思考可能是 $listeners
的问题,在 mounted
中打印也只有 @click
事件,就算去掉 $l本文来源gao@daima#com搞(%代@#码网@isteners
也不管用。 后来在浏览器对dom结构的查看,发现 limit-button
编译后变成:
可以看到编译后的 type
变成了 warning
,查 element
的源码可发现
<button class="el-button"> <i class="el-icon-loading"></i><i></i><span></span></button>
可发现是 $attrs
覆盖了 el-button
的nativeType
问题简化重现
<button type="primary">点击会刷新</button><button type="button">点击不会刷新</button>
重现链接
解决方法
将 type
分出来 props
,然后再通过 prop 引用
以上就是详解关于element el-button使用$attrs的一个注意要点的详细内容,更多请关注gaodaima搞代码网其它相关文章!