首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

深度讲解TS:这样学TS,迟早进大厂【11】:类型断言

当我们引用一个在此类型不存在属性或方法时,就会报错: const foo: number = 1; foo.length = 1; // index.ts:2:5 - error TS2339:...上面的例子中,数字类型的变量 foo 是没有 length 属性的,故 TypeScript 给出了相应的错误提示。 这种错误提示显然是非常有用的。...但有的时候,我们非常确定这段代码不会出错,比如下面这个例子: window.foo = 1; // index.ts:1:8 - error TS2339: Property 'foo' does not...上面的例子中,我们需要将 window 添加一个属性 foo,但 TypeScript 编译时会报错,提示我们 window 不存在 foo 属性。...此时我们可以使用 as any 临时将 window 断言为 any 类型: (window as any).foo = 1; 在 any 类型的变量,访问任何属性都是允许的。

1.2K20
您找到你想要的搜索结果了吗?
是的
没有找到

细数这些年被困扰过的 TS 问题

好的,下面我们来开始介绍第一个问题 —— 如何在 window 对象显式设置属性。...' does not exist on type 'Window & typeof globalThis'.(2339) 以上异常信息是说在 Window & typeof globalThis 交叉类型不存在...很明显 Combinable 和 number 类型的对象不存在 split 属性。问题又来了,那如何解决呢?这时我们就可以利用 TypeScript 提供的函数重载。...Object 类型:它是所有 Object 类的实例的类型,它由以下两个接口来定义: Object 接口定义了 Object.prototype 原型对象属性; // node_modules/typescript...// Error: Property 'prop' does not exist on type '{}'. obj.prop = "semlinker"; 但是,你仍然可以使用在 Object 类型定义的所有属性和方法

15K73

TypeScript

#类型断言 类型断言(Type Assertion)可以用来手动指定一个值的类型。 #什么是断言 有些情况下 TS 并不能正确或者准确得推断类型,这个时候可能产生不必要的警告或者报错。...any 但有的时候,我们非常确定这段代码不会出错,比如下面这个例子: window.foo = 'foo'; // index.ts:1:8 - error TS2339: Property 'foo...当我们向 window 添加一个 foo 时,会报错示我们 window 不存在 foo 属性。...当然,现在的编译器足够聪明,调用的时候可以不传递类型,编译器可以自己识别的 传递类型时,这个类型在函数中使用时的方法/属性,必须是存在的,或者继承自某个接口。...这里我有意使用不同的变量名,以表明类型值沿链向上传播,且与变量名无关。 #泛型约束 确保属性存在 当我们在函数中获取length属性,在类型为number时,是没有length的,所以会报错。

1.8K10

攀爬TS之路(一) 原始数据类型、任意值类型

实际,也算是必备知识了,印象最深的就是Element-Plus的示例代码都是TS了。 简介 TypeScript是JavaScript的超集(添加了类型系统),适用于任何规模的项目。...TS let num = 1 num.split('') // 类型“number”不存在属性“split”。 上面这段代码在编译阶段就会报错,能够提前知道问题所在。.../ 类型“number”不存在属性“split”。...如1+'1'不会报错 TS和JS都是弱类型 console.log(2 + '1') 在TS和JS中都不会报错,因为TS是完全兼容JS的,不会修改JS运行时的特性,所以它们都是弱类型。...原始数据类型 原始数据类型包括:number、string、boolean、null、undefined和Symbol、BigInt(ES6新增) 这个部分实际TS和JS差别不大,举个例子就能懂了。

69830
领券