vue3.x 中 computed 跟 ts 的寫法的一些坑

今天寫 demo 的時候 寫到 computed 我的想法是 modalFormRules 的 key 值都必須來源于 UserModalForm
如下圖所示:

type FormRule<T> = {
  [key in keyof T]: FormItemRule | Array<FormItemRule> | FormRules
}

interface UserModalForm {
  id?: number
  username: string
  sex?: number
  nick_name?: string
  phone?: string
  status: number
  email?: string
  roles?: number[]
}

const modalFormRules = computed<FormRule<UserModalForm>>(() => ({
  username: {
    required: true,
    message: 'Please enter a username',
    trigger: ['input'],
  },
  status: {
    required: true,
    message: 'Please select a status',
    trigger: ['blur', 'change'],
  },
  aaa: {
    required: true,
    message: 'Please enter aaaa',
    trigger: ['input'],
  },
}));

這時候是 TS 是不會報錯的 ,一直在想為啥不能報錯呢
換個寫法試試:

const modalFormRules = computed(() => {
  const rules:FormRule<UserModalForm> = {
  username: {
    required: true,
    message: 'Please enter a username',
    trigger: ['input'],
  },
  status: {
    required: true,
    message: 'Please select a status',
    trigger: ['blur', 'change'],
  },
  aaa: {
    required: true,
    message: 'Please enter aaaa',
    trigger: ['input'],
  }}
  return rules
}))

這樣寫 雖然 ts 報錯 aaa 不存在于 UserModalForm 中 感覺不夠優(yōu)雅
查閱了很久的資料都沒有說這個問題

最后

再次找了找網(wǎng)上的別人說的大致的內容如下:

computed<FormRule<UserModalForm>> 中添加 aaa 字段時,
TypeScript 可能不會直接在 computed 函數(shù)內部強制執(zhí)行嚴格的類型檢查脉课。
這是因為 TypeScript 在處理 computed 函數(shù)時,可能沒有深入推斷對象的類型煮仇。

結局方案如下:

const modalFormRules = computed((): Readonly<FormRule<UserModalForm>> => ({
  username: {
    required: true,
    message: '請輸入用戶名',
    trigger: ['input'],
  },
  status: {
    required: true,
    message: '請選擇狀態(tài)',
    trigger: ['blur', 'change'],
  },
  // 下面這一行會因為 'aaa' 不是 UserModalForm 的一部分而報錯
  // aaa: {
  //   required: true,
  //   message: '請輸入aaa',
  //   trigger: ['input'],
  // },
}));
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市谎仲,隨后出現(xiàn)的幾起案子浙垫,更是在濱河造成了極大的恐慌,老刑警劉巖郑诺,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件夹姥,死亡現(xiàn)場離奇詭異,居然都是意外死亡辙诞,警方通過查閱死者的電腦和手機辙售,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來飞涂,“玉大人圾亏,你說我怎么就攤上這事》馀。” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵夭问,是天一觀的道長泽西。 經(jīng)常有香客問我,道長缰趋,這世上最難降的妖魔是什么捧杉? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮秘血,結果婚禮上味抖,老公的妹妹穿的比我還像新娘。我一直安慰自己灰粮,他們只是感情好仔涩,可當我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著粘舟,像睡著了一般熔脂。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上柑肴,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天霞揉,我揣著相機與錄音,去河邊找鬼晰骑。 笑死适秩,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播秽荞,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼骤公,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了蚂会?” 一聲冷哼從身側響起淋样,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎胁住,沒想到半個月后趁猴,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡彪见,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年儡司,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片余指。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡捕犬,死狀恐怖,靈堂內的尸體忽然破棺而出酵镜,到底是詐尸還是另有隱情碉碉,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布淮韭,位于F島的核電站垢粮,受9級特大地震影響,放射性物質發(fā)生泄漏靠粪。R本人自食惡果不足惜蜡吧,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望占键。 院中可真熱鬧昔善,春花似錦、人聲如沸畔乙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽牲距。三九已至袖订,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間嗅虏,已是汗流浹背洛姑。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留皮服,地道東北人楞艾。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓参咙,卻偏偏與公主長得像,于是被迫代替她去往敵國和親硫眯。 傳聞我的和親對象是個殘疾皇子蕴侧,可洞房花燭夜當晚...
    茶點故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內容