之前需要对el-button
做二次封装,所以就用到vue
的$attrs
和$listeners
属性,这两个属性在这不细说,可以在 查看详情。
二次封装代码(limit-button)
复制代码
这样封装的好处就是不需要将上层每个属性都写一次prop
定义,对listeners
也不需要做一层中转emit
。
发现问题
在某个页面,点击经过封装的limit-button
会使页面进行刷新
- 起初以为是点击事件的冒泡产生的,就把上层引用的
@click
去掉:
点击 复制代码
发现还是一样会产生刷新的事件。
- 思考可能是
$listeners
的问题,在mounted
中打印也只有@click
事件,就算去掉$listeners
也不管用。 - 后来在浏览器对dom结构的查看,发现
limit-button
编译后变成: 可以看到编译后的type
变成了warning
,查element
的源码可发现复制代码
可发现是$attrs
覆盖了el-button
的nativeType
问题简化重现
复制代码
解决方法
将type
分出来props
,然后再通过 prop 引用
复制代码