溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

vue竊取道具類型的示例分析

發(fā)布時(shí)間:2022-03-16 14:51:08 來源:億速云 閱讀:140 作者:小新 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)vue竊取道具類型的示例分析,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

竊取道具類型

從子組件復(fù)制 prop 類型,只是為了在父組件中使用它們。但竊取這些道具類型比只是復(fù)制它們要好得多。

例如,我們Icon在這個(gè)組件中使用了一個(gè)組件:

<template>
  <div>
    <h3>{{ heading }}</h3>
    <Icon
      :type="iconType"
      :size="iconSize"
      :colour="iconColour"
    />
  </div>
</template>

為了讓它工作,我們需要添加正確的道具類型,從Icon組件中復(fù)制:\

import Icon from './Icon';
export default {
  components: { Icon },
  props: {
    iconType: {
      type: String,
      required: true,
    },
    iconSize: {
      type: String,
      default: 'medium',
      validator: size => [
        'small',
        'medium',
        'large',
        'x-large'
      ].includes(size),
    },
    iconColour: {
      type: String,
      default: 'black',
    },
    heading: {
      type: String,
      required: true,
    },
  },
};

當(dāng)Icon組件的 prop 類型更新時(shí),你肯定你會(huì)忘記回到這個(gè)組件并更新它們。隨著時(shí)間的推移,隨著該組件的 prop 類型開始偏離組件中的 prop 類型,將引入錯(cuò)誤Icon。

所以這就是為什么我們會(huì)竊取它們:

import Icon from './Icon';
export default {
  components: { Icon },
  props: {
    ...Icon.props,
    heading: {
      type: String,
      required: true,
    },
  },
};

除了在我們的示例中,我們?cè)诿總€(gè)道具名稱的開頭添加了“icon” 所以我們必須做一些額外的工作來實(shí)現(xiàn)這一點(diǎn):

import Icon from './Icon';

const iconProps = {};

// Do some processing beforehand
Object.entries(Icon.props).forEach((key, val) => {
  iconProps[`icon${key[0].toUpperCase()}${key.substring(1)}`] = val;
});

export default {
  components: { Icon },
  props: {
    ...iconProps,
    heading: {
      type: String,
      required: true,
    },
  },
};

現(xiàn)在,如果Icon組件中的 prop 類型被修改,我們的組件將保持最新。

但是如果在Icon組件中添加或刪除了一個(gè) prop 類型呢?為了涵蓋這些情況,我們可以使用v-bind計(jì)算道具來保持動(dòng)態(tài)。

關(guān)于“vue竊取道具類型的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

vue
AI