比如有个表单有一个 select 的 value 为 number 类型。 但是一般定义的时候都是:
// 这里 selectedValue 会被自动推导为 string 类型
const formModel = ref({
// ...
selectedValue: ''
})
虽然 select 选择值之后,打印 formModel.value.selectedValue 的值确实为 number ,但是会导致使用的时候类型推断错误,例如在接口中:
// api.ts
interface IRequest {
// ...
selectedValue: number
}
getList(params: IRequest):Promise<XXX> {
return axios.get('xxx', {params})
}
// page.vue
const getList = async() => {
const result = await api.getList({
// ...
// 这里会报错 selectedValue 是 string 类型而接口要求的是 number 类型
selectedValue: formModel.value.selectedValue
})
}
但是如果在 formModel 中将 selectedValue 定义为 number | string 类型,那就得把 IRequest 的也修改了,这感觉有点莫名其妙。因为后台确确实实要求的就仅仅是 number 而已。
请问给位大佬如何优雅的处理这个问题?
或者是将 selectedValue 设置为 undefined ?
const formModel = ref({
// ...
selectedValue: undefined
})
1
lupkcd 307 天前
undefined
|
2
Vegetable 307 天前
我怎么没看懂,const form = ref<{selectedValue:number|undefined}>({}) 这样不行吗
|
3
Vegetable 307 天前
|
4
17681880207 OP @lupkcd
感谢。因为我看到 arco design 和 element-plus 的处理方式是不同的。arco design 会变为 undefined 而 element-plus 会变为 ''(空字符串)。👻 |
5
hanai 307 天前 via iPhone
在 form 中,值就是字符串,默认为空字符串,提交时 parseInt
|
6
bojackhorseman 307 天前 via iPhone
使用 // @ts-expect-error 🤓
|