【译】如何提高我的 TypeScript 技能

在这篇文章中,我将向您展示我如何在 TypeScript 中提高自己的技能。我会向您介绍 5 个令人满意的操作符,这将帮助您更好地理解 TypeScript 和如何使用它。以下是我将要介绍的操作符:

  1. 非空断言操作符
  2. 可选链操作符
  3. 空合并操作符
  4. 明确类型断言
  5. 明确类型转换

1. 非空断言操作符

非空断言操作符是一个后置感叹号(!),它告诉 TypeScript,表达式的值不会是 null 或 undefined。这可以避免因为可能的 null 或 undefined 值而导致的类型错误。

示例:

const element: HTMLElement | null = document.getElementById("my-element");
const width: number = element!.offsetWidth;

在这里,element 可能为 null,但是我们使用非空断言操作符告诉 TypeScript 我们知道 element 的值不是 null,所以不会出现类型错误。

2. 可选链操作符

可选链操作符(?.)允许您在访问对象属性时不必担心属性是否存在。如果属性不存在,则返回 undefined

示例:

interface Person {
  name: string;
  address?: {
    city: string;
  };
}

const person: Person = {
  name: "John",
};

const city = person.address?.city;

在这里,address 属性是可选的,所以我们使用可选链操作符来安全地访问 city 属性,而不会抛出错误。

3. 空合并操作符

空合并操作符(??)是一种简洁的方式来提供默认值,当一个表达式的值为 null 或 undefined 时使用。

示例:

const value: number | null = null;
const defaultValue = 42;

const result = value ?? defaultValue;

在这里,当 value 为 null 时,result 的值将是 defaultValue

4. 明确类型断言

有时,您可能希望将一个类型明确地断言为另一个类型。您可以使用 <Type> 语法或 as Type 语法来实现这一点。

示例:

const input: unknown = "42";
const value: number = <number>(<string>input).length;

或者:

const input: unknown = "42";
const value: number = (input as string).length;

在这里,我们将 unknown 类型的 input 断言为 string,然后将其长度断言为 number

5. 明确类型转换

在某些情况下,您可能希望将一个值从一种类型转换为另一种类型。要执行此操作,您可以使用类型的构造函数。

示例:

const value: string = "42";
const numberValue: number = Number(value);

在这里,我们将 string 类型的 value 转换为 number 类型的 numberValue

了解这些操作符将帮助您更好地理解 TypeScript,并提高您的技能。希望您能善加利用这些操作符来提高您的 TypeScript 编程水平!

原文链接:https://dev.to/codeoz/how-i-improve-my-skills-in-typescript-5-satisfies-operator-2312


九旬的博客
关注我,每周输出一篇前端技术文章, 博客地址:[链接]

关注我,每周输出一篇前端技术文章,

1k 声望
1.2k 粉丝
0 条评论
推荐阅读
学会这些 Web API 使你的开发效率翻倍
随着浏览器的日益壮大,浏览器自带的功能也随着增多,在 Web 开发过程中,我们经常会使用一些 Web API 增加我们的开发效率。本篇文章主要选取了一些有趣且有用的 Web API 进行介绍,并且 API 可以在线运行预览。C...

九旬12阅读 1.5k

封面图
「多图预警」完美实现一个@功能
一天产品大大向 boss 汇报完研发成果和产品业绩产出,若有所思的走出来,劲直向我走过来,嘴角微微上扬。产品大大:boss 对我们的研发成果挺满意的,balabala...(内心 OS:不听,讲重点)产品大大:咱们的客服 I...

wuwhs39阅读 4.7k评论 5

封面图
安全地在前后端之间传输数据 - 「3」真的安全吗?
在「2」注册和登录示例中,我们通过非对称加密算法实现了浏览器和 Web 服务器之间的安全传输。看起来一切都很美好,但是危险就在哪里,有些人发现了,有些人嗅到了,更多人却浑然不知。就像是给门上了把好锁,还...

边城31阅读 7.1k评论 5

封面图
涨姿势了,有意思的气泡 Loading 效果
今日,群友提问,如何实现这么一个 Loading 效果:这个确实有点意思,但是这是 CSS 能够完成的?没错,这个效果中的核心气泡效果,其实借助 CSS 中的滤镜,能够比较轻松的实现,就是所需的元素可能多点。参考我们...

chokcoco19阅读 2k评论 2

在前端使用 JS 进行分类汇总
最近遇到一些同学在问 JS 中进行数据统计的问题。虽然数据统计一般会在数据库中进行,但是后端遇到需要使用程序来进行统计的情况也非常多。.NET 就为了对内存数据和数据库数据进行统一地数据处理,发明了 LINQ (L...

边城17阅读 1.9k

封面图
【已结束】SegmentFault 思否写作挑战赛!
SegmentFault 思否写作挑战赛 是思否社区新上线的系列社区活动在 2 月 8 日 正式面向社区所有用户开启;挑战赛中包含多个可供作者选择的热门技术方向,根据挑战难度分为多个等级,快来参与挑战,向更好的自己前进!

SegmentFault思否20阅读 5.6k评论 10

封面图
过滤/筛选树节点
又是树,是我跟树杠上了吗?—— 不,是树的问题太多了!🔗 相关文章推荐:使用递归遍历并转换树形数据(以 TypeScript 为例)从列表生成树 (JavaScript/TypeScript) 过滤和筛选是一个意思,都是 filter。对于列表来...

边城18阅读 7.6k评论 3

封面图

关注我,每周输出一篇前端技术文章,

1k 声望
1.2k 粉丝
宣传栏