關于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,
    },
  },

  computed: {
    ...mapGetters(['getUserBtns']),
    validButton: function() {
      return env.debug ? true : this.getUserBtns[this.buttonId];
    },
  },
};
</script>

這樣封裝的好處就是不需要將上層每個屬性都寫一次prop定義盆偿,對listeners也不需要做一層中轉emit柒爸。

發(fā)現(xiàn)問題

在某個頁面,點擊經(jīng)過封裝的limit-button會使頁面進行刷新

  1. 起初以為是點擊事件的冒泡產(chǎn)生的事扭,就把上層引用的@click去掉:
<limit-button
    type="warning"
    size="small"
    buttonId="2345434fg"
>
點擊
</limit-button>

發(fā)現(xiàn)還是一樣會產(chǎn)生刷新的事件捎稚。

  1. 思考可能是$listeners的問題,在mounted中打印也只有@click事件求橄,就算去掉$listeners也不管用今野。
  2. 后來在瀏覽器對dom結構的查看,發(fā)現(xiàn)limit-button編譯后變成:
    button

    可以看到編譯后的type變成了warning罐农,查element的源碼可發(fā)現(xiàn)
    <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>
    

可發(fā)現(xiàn)是$attrs覆蓋了el-button的nativeType

問題簡化重現(xiàn)

<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>

重現(xiàn)鏈接

解決方法

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,
    }
  },

  computed: {
    ...mapGetters(['getUserBtns']),
    validButton: function() {
      return env.debug ? true : this.getUserBtns[this.buttonId];
    },
  },
};
</script>

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市涵亏,隨后出現(xiàn)的幾起案子宰睡,更是在濱河造成了極大的恐慌蒲凶,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,376評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件夹厌,死亡現(xiàn)場離奇詭異豹爹,居然都是意外死亡,警方通過查閱死者的電腦和手機矛纹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評論 2 385
  • 文/潘曉璐 我一進店門臂聋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人或南,你說我怎么就攤上這事孩等。” “怎么了采够?”我有些...
    開封第一講書人閱讀 156,966評論 0 347
  • 文/不壞的土叔 我叫張陵肄方,是天一觀的道長。 經(jīng)常有香客問我蹬癌,道長权她,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,432評論 1 283
  • 正文 為了忘掉前任逝薪,我火速辦了婚禮隅要,結果婚禮上,老公的妹妹穿的比我還像新娘董济。我一直安慰自己步清,他們只是感情好,可當我...
    茶點故事閱讀 65,519評論 6 385
  • 文/花漫 我一把揭開白布虏肾。 她就那樣靜靜地躺著廓啊,像睡著了一般。 火紅的嫁衣襯著肌膚如雪封豪。 梳的紋絲不亂的頭發(fā)上谴轮,一...
    開封第一講書人閱讀 49,792評論 1 290
  • 那天,我揣著相機與錄音吹埠,去河邊找鬼书聚。 笑死,一個胖子當著我的面吹牛藻雌,可吹牛的內容都是我干的。 我是一名探鬼主播斩个,決...
    沈念sama閱讀 38,933評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼胯杭,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了受啥?” 一聲冷哼從身側響起做个,我...
    開封第一講書人閱讀 37,701評論 0 266
  • 序言:老撾萬榮一對情侶失蹤鸽心,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后居暖,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體顽频,經(jīng)...
    沈念sama閱讀 44,143評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,488評論 2 327
  • 正文 我和宋清朗相戀三年太闺,在試婚紗的時候發(fā)現(xiàn)自己被綠了糯景。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,626評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡省骂,死狀恐怖蟀淮,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情钞澳,我是刑警寧澤怠惶,帶...
    沈念sama閱讀 34,292評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站轧粟,受9級特大地震影響策治,放射性物質發(fā)生泄漏。R本人自食惡果不足惜兰吟,卻給世界環(huán)境...
    茶點故事閱讀 39,896評論 3 313
  • 文/蒙蒙 一通惫、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧揽祥,春花似錦讽膏、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至料按,卻和暖如春奄侠,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背载矿。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工垄潮, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人闷盔。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓弯洗,卻偏偏與公主長得像,于是被迫代替她去往敵國和親逢勾。 傳聞我的和親對象是個殘疾皇子牡整,可洞房花燭夜當晚...
    茶點故事閱讀 43,494評論 2 348

推薦閱讀更多精彩內容