82. TypeScript中的类型兼容性是怎么确定的?

在TypeScript中,类型兼容性是通过结构类型系统(structural type system)来确定的。结构类型系统关注的是类型的结构和成员的兼容性,而不仅仅关注类型的名称或声明。

TypeScript中的类型兼容性规则如下:https://www.nowcoder.com/issue/tutorial?zhuanlanId=Mg58Em&uuid=f8842a9cffea4857b416b8fc59e8156e

对象类型的兼容性:当一个对象需要与另一个对象兼容时,其属性的名称和类型必须兼容。这意味着目标对象可以拥有源对象的所有属性,并且属性的类型要么是兼容的,要么是可选的。此外,目标对象可以拥有额外的属性,但源对象没有的属性应该是可选的。

函数类型的兼容性:函数的兼容性取决于参数的兼容性和返回值的兼容性。对于函数参数,目标函数的参数类型应与源函数的参数类型兼容,或者源函数的参数类型应与目标函数的参数类型兼容。对于函数的返回值,目标函数的返回值类型应与源函数的返回值类型兼容。

类型关系的兼容性:TypeScript中的类之间,与对象类型类似,兼容性是基于结构而不是名称。这意味着一个类的实例可以赋值给另一个类,如果它们的属性结构相同。

泛型类型的兼容性:TypeScript中的泛型类型在判断兼容性时会考虑泛型参数的类型关系。当一个泛型类型与另一个泛型类型比较时,如果它们的泛型参数类型兼容,则它们是兼容的。

通过这些兼容性规则,TypeScript可以在类型检查过程中判断是否可以赋值或传递给其他类型,以提供更好的类型安全和编译时错误检测。
全部评论

相关推荐

📍面试公司:深圳即构科技💻面试岗位:前端实习❓面试问题:1.拷打LLM大模型项目:(1)实现的过程中遇到的跳转,以及怎么解决答:简单讲了markdown渲染和流式输出的实现(说的很简单)遇到的问题:多端适配(只讲了媒体查询实现)2.拷打智能家居项目:(1)技术选型,架构设计答:简单讲了uniapp的优点,websocket的优点3.八股(1)比较vue2和vue3,vue3好在哪里答:响应式原理vue3可读性更好,API(这块答的不好)(2)vue双向绑定原理答:只用过,原理大概prop监听?(答的稀烂)(3)css盒模型正常回答,(他说我笔试做错了这道题,我忘了怎么这个题都能错)(4)事件循环机制答:先同步,再微任务,再宏任务(让我说了哪些微任务,哪些宏任务)(5)typescript里interface和type都可以用来定义对象吗答:不太懂typescript(6)CI CD流水线的实现答:简单说了用gitlab实现(7)虚拟滚动的原理(8)前端的其他性能优化答:防抖、节流、图片懒加载4.开放问题(1)前端的未来发展,AI的影响答:前端与人交互性强,AI代替不了,但可以用AI帮助开发(大概这种)(2)在项目开发里充当leader,临近deadline,发现了依赖第三方库的bug,怎么解决答:随便乱说的5.反问(1)实习生具体做什么(2)我哪些方面需要加强  表达能力可以,但是让我主动说自己的亮点,讲讲问题怎么解决的(3)面试结果什么时候出🙌面试感想:感觉答的还凑合,但让我说亮点 ,事实上没什么亮点hhhh
查看18道真题和解析
点赞 评论 收藏
分享
时长45分钟 欢聚集团1.什么是盒子模型2.日常开发中使用过什么选择器3.伪元素和伪类的区别(css 问题到此为止)4.讲讲什么是闭包,闭包有什么优点,会出现什么问题5.讲讲 this 的指向问题6.讲讲原型和原型链7.原型链有什么用8.讲讲类型断言和类型解释(typeof,instanceof)的区别9.我看你使用过 typescript,讲讲你为什么使用 typescript10.讲讲你对 js 和 ts 的区别的理解11.讲讲你对明明使用静态语言却还用 any 的看法12.你在代码中会用 any 吗(我说一般会定义 interface)13.讲讲定义 interface 和 any 之间的区别(js/ts 的问题应该是到此为止,可能还有但不记得了)14.讲讲你对 hooks,函数式组件,类式组件的区别(本人从生命周期的角度回答)15.你认为 hooks 有什么缺点(本人说只能在外部使用,在 if 和 while 不可使用,可能不是很灵活)16.你知道为什么 hooks 不能在外部使用吗?17.如果我有在 if 和 while 中使用 hooks 有什么解决方案吗(人麻了)18.如果是你,你会根据什么角度来选择使用 useEffect 和 useLayoutEffect19.讲讲你对 useContext 的理解20.useContext、zustand 和 Redux 的区别因为腾讯会议时长只约了 30 分钟,到这里应该 30 分钟了,可能还有一些问题但是我忘了(悲)你的项目中有什么亮点吗,可以和我说一下(现场看我简历,于是延长了 15 分钟。。。)21.讲讲你项目中的一些功能22.我看你会做一些性能优化,你是怎么实现的呢23.你为什么会想着去优化压缩项目体积呢24.你说你使用了 http/2,为什么 http/2 能比 http/1.1 更加节省资源呢25.怎么看到资源更加节省了呢26.你对虚拟列表的原理有了解吗27.你的项目中是一开始就使用了 vite 吗28.为什么会想着做一个中间件呢29.你提到你了解 NodeJS,有使用过吗30.讲讲 useCallback,useMemo31.具体讲讲 useMemo反问环节45 分钟全是八股,人麻了时长 45 分钟 中科紫东太初1.我对你的第一个项目比较感兴趣,有在线网址吗2.你的动画挺好看,使用了哪些库3.讲讲中间件的功能4.查询准确率只有 85%,可是对于后端这样需要准确率较高的场景会不会有什么问题5.是怎么记录首屏加载时间的6.你是怎么实现 CI/CD 的手撕题:React todolist面试官人很温柔,基本一直在提醒,看我在思考,还写了一段代码给我看(感动)## 总结一天两场面试,累倒也没有,还是有得到锻炼发现了自己的不足
挽风ovo:学弟加油 才27还有很多时间
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务