搜尋

首頁  >  問答  >  主體

Typescript:來自元組數組的動態列表,沒有交集

<p><pre class="brush:php;toolbar:false;">const intents = ["primary", "secondary", "accent", "danger"] 或 constt; const buttonSizes = ["small", "medium", "big"] as const; type IntentType = (typeof intents)[number]; type SizeType = (typeof buttonSizes)[number]; type ButtonProps = { intent?: IntentType; size?: SizeType; } & { [K in IntentType as `${Lowercase<K>}`]?: boolean; };</pre> <p>在這段程式碼中,我希望 Vue 元件能夠接收以下屬性 </p> <p>或者 喜歡 </p> <p>now, if I write the code more statically, 讚:</p> <pre class="brush:php;toolbar:false;">type ButtonProps = { intent?: "primary" | "secondary" | "accent" | "danger"; size?: "small" | "medium" | "big"; primary?: boolean; secondary?: boolean; accent?: boolean; danger?: boolean; }</pre> <p>它有效......但是我還有一些其他程式碼需要迭代意圖選項,並且只是讓它一直重複......</p> <p>第一個範例有效,但由於某些原因 VUE 拋出錯誤</p> <blockquote> <p>內部伺服器錯誤:[@vue/compiler-sfc] 類型參數傳遞給 DefineProps() 必須是文字類型或對介面的引用 或文字類型。 </p> </blockquote> <p>這個錯誤似乎是已知的並且正在解決,所以看起來</p> <p>在不使用交集的情況下更動態地定義 ButtonProps 的其他方法是什麼? </p>
P粉163951336P粉163951336500 天前505

全部回覆(1)我來回復

  • P粉384244473

    P粉3842444732023-09-01 18:26:56

    鑑於錯誤顯示“引用介面或文字類型”,我假設將 ButtonProps 定義為擴展基本類型的介面應該有效:

    type IntentAndSize = {
      [K in IntentType as `${Lowercase<K>}`]?: boolean;
    };
    
    interface ButtonProps extends IntentAndSize {
      intent?: IntentType;
      size?: SizeType;
    }

    遊樂場

    #

    回覆
    0
  • 取消回覆