详解关于element el-button使用$attrs的一个注意要点
网络编程 2021-07-04 16:47www.168986.cn编程入门
这篇文章主要介绍了详解关于element el-button使用$attrs的一个注意要点,长沙网络推广觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
之前需要对 el-button
做二次封装,所以就用到 vue
的 $attrs
和 $listeners
属性,这两个属性在这不细说,可以在这里 查看详情。
二次封装代码(limit-button)
<template> <el-button v-show="validButton" v-bind="$attrs" v-on="$listeners" > <slot></slot> </el-button> </template> <script> import { mapGetters } from 'vuex'; import env from '@/config/env'; export default { props: { // 按钮唯一标识 buttonId: { type: String, required: true, }, }, puted: { ...mapGetters(['getUserBtns']), validButton: function() { return env.debug ? true : this.getUserBtns[this.buttonId]; }, }, }; </script>
这样封装的好处就是不需要将上层每个属性都写一次 prop
定义,对 listeners
也不需要做一层中转 emit
。
发现问题
在某个页面,点击经过封装的 limit-button
会使页面进行刷新
起初以为是点击事件的冒泡产生的,就把上层引用的 @click
去掉:
<limit-button type="warning" size="small" buttonId="2345434fg" > 点击 </limit-button>
发现还是一样会产生刷新的事件。
思考可能是 $listeners
的问题,在 mounted
中打印也只有 @click
事件,就算去掉 $listeners
也不管用。 后来在浏览器对dom结构的查看,发现 limit-button
编译后变成
可以看到编译后的 type
变成了 warning
,查 element
的源码可发现
<button class="el-button" @click="handleClick" :disabled="buttonDisabled || loading" :autofocus="autofocus" :type="nativeType" ... > <i class="el-icon-loading" v-if="loading"></i> <i :class="icon" v-if="icon && !loading"></i> <span v-if="$slots.default"><slot></slot></span> </button>
可发现是 $attrs
覆盖了 el-button
的nativeType
问题简化重现
<el-form ref="form" :model="form" label-width="80px"> <el-form-item> <button type="primary">点击会刷新</button> <button type="button" @click="onSubmit">点击不会刷新</button> </el-form-item> </el-form>
解决方法
将 type
分出来 props
,然后再通过 prop 引用
<template> <el-button :type="type" v-show="validButton" v-bind="$attrs" v-on="$listeners" > <slot></slot> </el-button> </template> <script> import { mapGetters } from 'vuex'; import env from '@/config/env'; export default { props: { // 按钮唯一标识 buttonId: { type: String, required: true, }, type: { type: String, } }, puted: { ...mapGetters(['getUserBtns']), validButton: function() { return env.debug ? true : this.getUserBtns[this.buttonId]; }, }, }; </script>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程