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: []})

编辑器会发生报错

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

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

相关推荐
努力奋斗12 小时前
VUE-第二季-02
前端·javascript·vue.js
胡西风_foxww4 小时前
TypeScript 元组类型精简知识点
前端·typescript·类型·元祖
JSON_L4 小时前
Vue 详情模块 3
前端·javascript·vue.js
濮水大叔7 小时前
如何基于动态关系进行ORM关联查询,并动态推断DTO?
typescript·node.js·orm
神仙别闹8 小时前
基于Vue+Node.js(Express)实现(Web)物联网的蔬菜大棚温湿度监控系统
前端·vue.js·node.js
x吴文龙9 小时前
不再踩坑,在Vue3+vite安装UNOCSS
前端·vue.js
拾光拾趣录9 小时前
让 Vue 动起来!用 Motion for Vue 打造丝滑交互的实战指南
前端·vue.js
泉城老铁10 小时前
在 Element UI 中将 el-radio-group改为纵向排列
前端·vue.js
黑土豆10 小时前
【Vue3 实战】从0到1封装一个“框选截图”组件,顺便聊聊 html2canvas 的那些“坑”
前端·javascript·vue.js
EF@蛐蛐堂10 小时前
Lodash 的终极进化Radashi
前端·javascript·vue.js