我的编程空间,编程开发者的网络收藏夹
学习永远不晚

TypeScript之为什么停止使用any

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

TypeScript之为什么停止使用any

这篇文章主要介绍“TypeScript之为什么停止使用any”,在日常操作中,相信很多人在TypeScript之为什么停止使用any问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”TypeScript之为什么停止使用any”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

什么是 any

因此 any  不是通配符,也不是基类型,它是明确地与第三方库进行交互。那它为什么经常出现你呢?它对我们的系统有害吗?我们应该逃避它还是拥抱它?

any 类型是使用现有 JavaScript 的强大方法,可让您在编译期间逐渐选择加入和选择退出类型检查。

TypeScript 文档明确表达了当我们使用any类型时,我们正在告诉编译器:

TypeScript之为什么停止使用any

当超过500名该语言的贡献者提供帮助时,我们说 no thank  you。这听起来像是选择退出类型检查器,有了它,就不能轻易地放弃对类型系统的所有安全性和信心。我们应该使用它来与无类型的第三方(或第一方) Javascript  代码交互,或者当我们只知道类型的一部分时。

但是等等我还有很多其他原因

(1) TypeScript 不会转换为 Javascript 吗?Javascript  不是动态的吗?那我为什么要考虑我的类型呢?

是的!但是我们用 TypeScript 写代码,这是一种静态类型语言。有人可能会说静态类型语言不会比动态语言产生更少的 bug 。不过,在使用 any  之类的静态类型语言中,这是两种情况中最糟糕的。

(2) 有些参数很难正确输入,但是 any 更容易

如果我们没有正确地输入,我们将会编写错误,比我们在动态语言中会编写更多的错误,因为我们强制 TypeScript  ,一种静态类型语言,去检查不正确的类型。

(3) 我真的不知道参数是什么

没关系!我们可以用 unknown ; 它允许我们确实分配任何类型。但在确定特定类型之前,我们将不允许使用这些值。

type ParsedType = {   id: number }  const parseApiResponse(   response: Record<string, unknown> ): ParsedType => {   const convertedResponse = (response as ParsedType)    // without doing the type cast we would   // get a type error here   if(convertedResponse.id >= 0) {     return convertedResponse   } else {     throw Error.new("Invalid response"   } }

(4) 添加类型时,我必须编写大量代码,any工作量较少

可能不是,如果编写的代码没有类型,则我们可能需要添加防御性代码,以确保参数和变量具有正确的类型,以使程序能够按预期执行。any 甚至无法防范 null 或  undefined 检查我们的逻辑 。

// version 1 with `any` const fullName = (user: any) => {   if (user?.firstName && user?.lastName) {     return `${user.lastName}, ${user.firstName}`   }    return user?.firstName || "" }  // version 1 without `any`  interface User {   firstName: string   lastName?: string }  const fullName = ({ firstName, lastName }: User) => {   if (lastName === undefined) {     return firstName   }    return `${lastName}, ${firstName}`; }

(5) 类型增加了很多复杂性,有时any更简单

使用 any  可能允许我们在不考虑数据如何流入逻辑的情况下更简单的开发。但它将这个负担会转移到我们代码的未来读者身上。他们将不得不在没有上下文和编译器帮助的情况下解释发生了什么。

(6) 有了文档,我可以提供所有上下文

添加类型时,我们会从编译器获得帮助,并且会获得不会随时间推移而衰减的文档,因为如果过时了,我们的代码将无法编译。

const intersection = (a: any, b: any): any => { ... } const intersection = (   a: Set<number>, b: Set<number> ): Set<number> => { ... }

它们都是等效的,但是读者会更好地了解后面的函数在做什么,而不是从第一个函数开始。

(7) 我已经通过必要的运行时检查以防御性的方式编写了代码,以确保没有错误

现在可能没有错误,但是除非你有很好的测试覆盖率,否则以后来修改代码的人不会相信他们不是在错误中重构;就好像编译器不会帮你,因为我们说过它不会帮你。如果我们显式地设置类型并更改系统中使用的API,编译器将提供它的指导。

(8) 如果以后我改变主意怎么办?我可能会为此重构几个小时

我们总是可以修改和适应新的类型定义, TypeScript 为此提供了一组实用功能。我们可以 Pick 习惯从先前定义的类型中选择所需的属性。Omit  得到除少数几个以外的所有东西。Partial 使所有属性都是可选的,或进行完整的180并使其全部Requireds。

type User = {   id: number;   firstName: string;   lastName: string;   age: number; }  type UserParams =   Pick<User, "id"> & Partial<Omit<User, "id">>  const updateUser = (   { id, ...newUserParams }: UserParams ) => {   {...} }

(9) 很好,从TypeScript中删除 any,立即打开PR

让我们深吸一口气, any 它在正确的情况下非常强大且有用。

  • 与使用它的库接口;确保在将数据移至系统之前尽快将其转换为正确的类型。

  • 解决 TypeScript 类型错误;如果我们发现自己无法输入某些内容,则 any  可能有必要。但是只有在尝试其他所有方法之后才推荐使用。如果使用它,我们应该将其重新转换为可预测的类型。

  • 如果我们的函数可以真正处理任何类型,那么这种情况很少见,并且是偶然的(例如调试或日志记录函数)。在这些情况下,我们需要 100%  确保不存在会导致函数失败的类型。我们应该检查函数的主体,并根据输入确定最基本的形状并加以限制。例如,如果我们要打印某些内容,则至少应验证它是否响应  toString 。

到此,关于“TypeScript之为什么停止使用any”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

TypeScript之为什么停止使用any

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android Compose之Animatable动画停止怎么使用

本篇内容主要讲解“Android Compose之Animatable动画停止怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android Compose之Animatable动画停止怎
2023-07-05

XP停止服务是什么意思?停止服务后还能继续使用吗?

微软从今天开始正式停止对Windows XP系统更新,各大媒体也纷纷对XP停止服务进行了大量的相关报道。笔者在各大媒体的报道评论中,发现不少网友对比XP停止服务时什么意思,以及对于XP停止服务后还能用吗,充满疑问,以下笔者为大家带来详细的相
2023-06-04

为什么禁止使用Apache Beanutils进行属性的copy

这篇文章主要讲解了“为什么禁止使用Apache Beanutils进行属性的copy”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“为什么禁止使用Apache Beanutils进行属性的co
2023-06-16

为什么禁止使用BigDecimal的equals方法做等值比较

本篇内容介绍了“为什么禁止使用BigDecimal的equals方法做等值比较”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!BigDecim
2023-06-16

为什么要禁止使用BigDecimal的equals方法做等值比较

本文小编为大家详细介绍“为什么要禁止使用BigDecimal的equals方法做等值比较”,内容详细,步骤清晰,细节处理妥当,希望这篇“为什么要禁止使用BigDecimal的equals方法做等值比较”文章能帮助大家解决疑惑,下面跟着小编的
2023-06-27

为什么Java中要求超大整数禁止使用Long类型返回

本篇内容主要讲解“为什么Java中要求超大整数禁止使用Long类型返回”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“为什么Java中要求超大整数禁止使用Long类型返回”吧!错误演示创建一个 S
2023-06-16

使用using backup controlfile恢复db之后为什么需要resetlogs

这篇文章主要为大家展示了“使用using backup controlfile恢复db之后为什么需要resetlogs”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“使用using backup
2023-06-04

javascript浏览器的停止按钮被按下时触发此事件或者正在下载的文件被中断使用什么函数,详细讲解

当用户点击浏览器停止按钮或中断文件下载时,JavaScript会触发特定事件。停止按钮事件(window.onbeforeunload)允许开发者:询问用户是否离开页面保存未保存的数据返回字符串提示用户确认停止操作文件下载中断事件(XMLHttpRequest.onabort)允许开发者:显示下载中断消息重新启动下载事件处理最佳实践包括:用户确认数据保存错误处理轻量级操作一致性
javascript浏览器的停止按钮被按下时触发此事件或者正在下载的文件被中断使用什么函数,详细讲解
2024-04-02

编程热搜

目录