2022-04-27 el-switch組件實現(xiàn)beforeChange

今天遇到了一個需求:點擊Switch更改音頻是否打開各薇,我需要在設(shè)置請求響應(yīng)之后再改變Switch的狀態(tài)遇汞。于是自己把el-switch組件進行了二次封裝撒遣。

<template>
  <el-switch
    :value="_value"
    @change="onChange"
    v-bind="$attrs"
    :activeValue="activeValue"
    :inactiveValue="inactiveValue"
  >
  </el-switch>
</template>

重新綁定value值载城,和change事件最铁,其余參數(shù)使用attrs傳遞(attrs 可以收集父組件中的所有傳過來的屬性除了那些在子組件中通過 props 定義的。

type valueType = string | number | boolean;
type fnType = (arg: valueType) => Promise<boolean>;
props: {
    activeValue: {
      type: [String, Number, Boolean],
      default: true,
    },
    inactiveValue: {
      type: [String, Number, Boolean],
      default: false,
    },
    beforeChange: {
      type: Function as PropType<fnType>,
    },
    value: {
      type: [String, Number, Boolean],
      default: false,
    },
  },

props定義父組件傳入的屬性

data() {
    return {
      _value: '' as valueType,
    };
  },
  created() {
    this._value = this.value;        // 將父組件傳入的value值賦值給子組件
  },
  watch: {
    value: function(v) {
      this._value = v;
    },
  },

監(jiān)聽父組件傳入的value值垮兑,并賦值給子組件

onChange(changeVal: valueType) {
      // 定義一個變量存儲改變之前的值
      let beforeVal: valueType;
      // 保存狀態(tài)改變之前的值
      if (this.activeValue !== '' && this.inactiveValue !== '') {
        beforeVal =
          changeVal === this.activeValue
            ? this.inactiveValue
            : this.activeValue;
      } else {
        beforeVal = !changeVal;
      }

      if (this.beforeChange != null) {
        // 傳入組件changeVal
        this.beforeChange(changeVal)
          .catch(() => {
            changeVal = beforeVal;
          })
          .finally(() => {
            // 請求不管成功還是失敗最終會進到這里冷尉,成功時changeVal值不變,失敗時修改為改變之前的值
            this._value = changeVal;
            this.$emit('change', changeVal);
            // 拋出input事件系枪,修改視圖
            this.$emit('input', changeVal);
          });
      }
    },

父組件的beforeChange方法雀哨,返回一個Promise,成功狀態(tài)為修改switch狀態(tài)私爷,失敗則為修改前的狀態(tài)

setAduioState(state: boolean): Promise<boolean> {
      return new Promise((reslove, reject) => {
        // 定時器設(shè)置禁用雾棺,防止頻繁點擊
        setTimeout(() => {
          this.audioDisabled = false;
        }, 2000);
        if (!this.audioDisabled) {
          request
            .serve({
              method: 'post',
              url: '/setAudioSwitch',
              data: qs.stringify({ state: state }),
            })
            .then((res: any) => {
              if (res.errorCode === 200) {
                reslove(true);
              } else {
                // 拋出異常
                throw new Error('設(shè)置錯誤');
              }
            })
            .catch(() => {
              reject(false);
            });
        }
        this.audioDisabled = true;
      });
    },
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市衬浑,隨后出現(xiàn)的幾起案子捌浩,更是在濱河造成了極大的恐慌,老刑警劉巖工秩,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件尸饺,死亡現(xiàn)場離奇詭異进统,居然都是意外死亡,警方通過查閱死者的電腦和手機浪听,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進店門螟碎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人迹栓,你說我怎么就攤上這事掉分。” “怎么了克伊?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵酥郭,是天一觀的道長。 經(jīng)常有香客問我答毫,道長褥民,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任洗搂,我火速辦了婚禮消返,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘耘拇。我一直安慰自己撵颊,他們只是感情好,可當我...
    茶點故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布惫叛。 她就那樣靜靜地躺著倡勇,像睡著了一般。 火紅的嫁衣襯著肌膚如雪嘉涌。 梳的紋絲不亂的頭發(fā)上妻熊,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天,我揣著相機與錄音仑最,去河邊找鬼扔役。 笑死,一個胖子當著我的面吹牛警医,可吹牛的內(nèi)容都是我干的亿胸。 我是一名探鬼主播,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼预皇,長吁一口氣:“原來是場噩夢啊……” “哼侈玄!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起吟温,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤序仙,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后鲁豪,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體诱桂,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡洋丐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了挥等。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片友绝。...
    茶點故事閱讀 39,965評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖肝劲,靈堂內(nèi)的尸體忽然破棺而出迁客,到底是詐尸還是另有隱情,我是刑警寧澤辞槐,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布掷漱,位于F島的核電站,受9級特大地震影響榄檬,放射性物質(zhì)發(fā)生泄漏卜范。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一鹿榜、第九天 我趴在偏房一處隱蔽的房頂上張望海雪。 院中可真熱鬧,春花似錦舱殿、人聲如沸奥裸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽湾宙。三九已至,卻和暖如春冈绊,著一層夾襖步出監(jiān)牢的瞬間侠鳄,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工死宣, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留伟恶,地道東北人。 一個月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓十电,卻偏偏與公主長得像,于是被迫代替她去往敵國和親叹螟。 傳聞我的和親對象是個殘疾皇子鹃骂,可洞房花燭夜當晚...
    茶點故事閱讀 44,914評論 2 355

推薦閱讀更多精彩內(nèi)容