比如有个表单有一个 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
})
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.