ts+vue3出乎意料的推导报错

今天在写代码时候,发现一个让我琢磨不透的报错。通过官网得知2种写法效果是一样的。但是偏偏有一种会类型推导报错。代码如下:

typescript 复制代码
export interface AddRoleParams {
  name: string;
  description: string,
  menus: object[]
}

export interface EditRoleParams extends AddRoleParams {
  id: number,
}

export interface ListItem {
  id: number;
  [key: string]: unknown;
}

const b =  ref<EditRoleParams>({ id: 0, name: '', description: '', menus: []})
export function a(params:Ref<ListItem> | Reactive<ListItem>){ 
  console.log(params)
}

a(b)

上面的代码是正常的,如果把b的赋值改成这个

php 复制代码
const b: Ref<EditRoleParams> =  ref({ id: 0, name: '', description: '', menus: []})

编辑器会发生报错

但是从官网上来看效果应该是一样的。

不过我也没找到是啥原因。

相关推荐
用户658681803384017 分钟前
Vue3 项目编码规范:基于Composable的清晰架构实践
vue.js
小酒星小杜18 分钟前
在AI时代,技术人应该每天都要花两小时来构建一个自身的构建系统 - Build 篇
前端·vue.js·架构
zengyufei20 分钟前
2.4 watch 监听变化
vue.js
奔跑的web.21 分钟前
TypeScript 全面详解:对象类型的语法规则
开发语言·前端·javascript·typescript·vue
m0_4711996336 分钟前
【小程序】订单数据缓存 以及针对海量库存数据的 懒加载+数据分片 的具体实现方式
前端·vue.js·小程序
如果你好39 分钟前
TypeScript 全面详解:对象类型的语法规则与实战指南
typescript
貂蝉空大1 小时前
vue-pdf-embed分页预览解决文字丢失问题
前端·vue.js·pdf
满天星辰1 小时前
Typescript的infer到底怎么使用?
前端·typescript
ss2731 小时前
RuoYi-App 本地启动教程
前端·javascript·vue.js
用户248257824811 小时前
vue3快速入门
vue.js