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

编辑器会发生报错

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

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

相关推荐
咖啡の猫26 分钟前
Vue 实例生命周期
前端·vue.js·okhttp
JNU freshman40 分钟前
vue 之 import 的语法
前端·javascript·vue.js
剑亦未配妥41 分钟前
Vue 2 响应式系统常见问题与解决方案(包含_demo以下划线开头命名的变量导致响应式丢失问题)
前端·javascript·vue.js
爱吃的强哥44 分钟前
Vue2 封装二维码弹窗组件
javascript·vue.js
凉柚ˇ44 分钟前
Vue图片压缩方案
前端·javascript·vue.js
优弧1 小时前
Vue 和 React 框架对比分析:优缺点与使用场景
vue.js
Kimser2 小时前
基于 VxeTable 的高级表格选择组件
前端·vue.js
533_2 小时前
[element-ui] el-tree 组件鼠标双击事件
前端·javascript·vue.js
麦麦大数据3 小时前
F031 Vue+Flask深度学习+机器学习多功能识别系统
vue.js·深度学习·flask