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

编写高质量可维护的代码:Awesome TypeScript

Typescript VS Javascript JavaScript JavaScript 是动态类型语言,在代码编译阶段不会对变量进行类型检测,从而会把潜在的类型错误带到代码执行阶段。...TypeScript TypeScript 是静态类型语言,通过类型注解提供编译时的静态类型检查。 在代码编译阶段会进行变量的类型检测,提前暴露潜在的类型错误问题。...泛型允许同一个函数接受不同类型参数,相比于使用 Any 类型,使用泛型来创建的组件可复用和易扩展性要更好,因为泛型会保留参数类型。泛型可以应用于接口、类、变量。...因为类型报错不会影响代码生成和执行,所以原则上还是会存在 fn('str') 调用的可能性,所以需要 default 进行兜底的防御性代码。...": true, // 有未使用的参数时,抛出错误 "noImplicitReturns": true, // 并不是所有函数里的代码都有返回值时,抛出错误

2.4K10

4000字讲清 《深入理解TypeScript》一书 【基础篇】

有了以上假设,从 JavaScript 迁移,总的来说包括以下步骤: 添加一个 tsconfig.json文件; 把文件扩展名从 .js 改成 .ts,开始使用 any 来减少错误; 开始在 TypeScript...它自然被分配的一些例子: 一个从来不会有返回值的函数(如:如果函数内含有 while(true) {}); 一个总是会抛出错误的函数(如:function foo() { throw new Error...当一个函数没有返回值时,它返回了一个 void 类型,但是,当一个函数根本就没有返回值时(或者总是抛出错误),它返回了一个 never,void 指可以被赋值的类型(在 strictNullChecking...为 false 时),但是 never 不能赋值给其他任何类型,除了 never TypeScript 索引签名 JavaScript 在一个对象类型的索引签名上会隐式调用 toString 方法...,它将会抛出一个错误。

1.9K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    TypeScript 官方手册翻译计划【一】:基础

    要让纯 JavaScript 告诉我们 fn 在给定特定参数的时候会做什么事,唯一的方法就是实际调用 fn 函数。...那么不妨我们改用一种方案,使用一个静态的类型系统,在代码实际执行前预测代码的行为。 静态类型检查 还记得之前我们将字符串作为函数调用时,抛出的 TypeError 错误吗?...这些异常之所以能够抛出,是因为 ECMAScript 规范 明确规定了针对异常应该表现的行为。 举个例子,规范指出,试图调用无法调用的东西应该抛出一个错误。...所以在设计上,TypeScript 并不会对你造成阻碍。当然,随着时间的推移,你可能希望对错误采取更具防御性的措施,同时也让 TypeScript 采取更加严格的行为。...启用 noImplicitAny 配置项,在遇到被隐式推断为 any 类型的变量时就会抛出一个错误。

    92010

    深入浅出TypeScript | 青训营笔记

    什么时候需要泛型 2. 泛型是什么 泛型(Generics)是一种参数化类型的机制,可以让我们在定义函数、类和接口时,使用一个或多个类型作为参数来指定其返回值或成员的类型。...就是临时占个位置, 之后通过传递过来的参数进行推导 使用泛型时,我们需要在函数、类或接口名称后面加上尖括号 ,其中 T 代表泛型类型参数名。...使用推断类型的方式调用这个函数时,TypeScript 会自动根据传入参数的类型推导出泛型类型 T 的具体类型。...需要注意的是,在使用泛型时,我们还可以对泛型类型参数进行约束,以限制它们只能是某个特定类型或其子类型。..., // 有未使用的参数时,抛出错误 "noImplicitReturns": true, // 并不是所有函数里的代码都有返回值时,抛出错误

    8410

    帮助编写异步代码的ESLint规则

    应将该值传递给resolve,如果发生错误,则调用 reject 并告知错误信息。 该规则不会阻止你在 Promise 构造函数中的嵌套回调内返回值。...这就造成了一个竞赛条件,当值在单独的函数调用中更新时,更新不会反映在当前函数的作用域中。因此,这两个函数都将其结果添加到 totalPosts 的初始值 0 中。...忘记处理错误会导致应用程序行为异常。 当函数的第一个参数名为 err 时,就会触发该规则。在大型项目中,经常会发现不同的错误命名方式,如 e 或 error。...node/no-callback-literal 该规则强制要求在调用回调函数时将 Error 对象作为第一个参数。如果没有错误,也接受 null 或 undefined。...; callback(null, result); 该规则可确保你不会意外调用第一个参数为非错误的回调函数。

    24210

    TypeScript 常用知识总结

    TypeScript 通过类型注解提供编译时的静态类型检查。 TypeScript 中的数据要求带有明确的类型,JavaScript不要求。 TypeScript 为函数提供了缺省参数值。...TypeScript 引入了命名空间 TypeScript 的优势 静态输入: 静态类型化是一种功能,可以在开发人员编写脚本时检测错误。查找并修复错误是当今开发团队的迫切需求。...更好的协作: 当开发大型项目时,会有许多开发人员,此时乱码和错误的机也会增加。类型安全是一种在编码期间检测错误的功能,而不是在编译项目时检测错误。这为开发团队创建了一个更高效的编码和调试过程。...三、TypeScript 的组成 模块 函数 变量 语句和表达式 注释 四、tsc 常用编译参数 参数作用--help显示帮助信息--module载入扩展模块--target设置 ECMA 版本--declaration...这意味着声明为 never 类型的变量只能被 never 类型所赋值,在函数中它通常表现为抛出异常或无法执行到终止点(例如无限循环) 变量不要使用 name 否则会与 DOM 中的全局 window 对象下的

    1.8K30

    【TypeScript】超详细的笔记式教程【上】

    上述的Ts栗子中有一个点,就是:指定类型。 注意: Ts只会在编译与书写代码的过程中给你相关的警告,在Js的执行中并不会有这样的警告,编译完的Js代码也不会插入相关的校验代码。...如果我们在调用sayHelloWorld的时候,传入一个123,会出现以下情况: 情况一:编辑器会有提示,这时候看到提示,我们就可以修改代码。...true, // 不允许函数参数双向协变 "strictPropertyInitialization": true, // 类的实例属性必须初始化 "strictBindCallApply":..., // 检查只声明、未使用的局部变量(只提示不报错) "noUnusedParameters": true, // 检查未使用的函数参数(只提示不报错) "noFallthroughCasesInSwitch...需要注意的是,如果你没有初始化变量,那就是any类型 let age; age = 1 age = true 这样完全Ok,并不会抛出错误,这样写类似于: let age: any; 联合类型 联合类型就是一个变量可以有多个类型

    1.1K30

    TypeScript 中 unknown 与 any 有啥区别

    1. unknown vs any 为了更好地理解 unknown 和 any 之间的区别,我们先从编写一个想要调用其唯一参数的函数开始。...(1); // throws "TypeError: callback is not a function" 因为 callback 参数是任何类型的,所以语句 callback() 不会触发类型错误。...1 是一个数字,不能作为函数调用,TypeScript并没有保护代码避免这个错误 那既允许 invokeAnything() 函数接受任何类型的参数,又要强制对该参数进行类型检查防止上面这种报错,要怎么做呢...但是当尝试使用 unknown 变量时,TypeScript 会强制执行类型检查。这不就是我们想要的嘛。...与 any 相反,TypeScript会保护我们不调用可能不是函数的东西。 在使用一个 unknown 类型的变量之前,你需要进行类型检查。

    47921

    Reac19 升级指南

    在之前的 React 版本中,渲染过程中抛出的错误会被捕获并重新抛出。...在 React 19 中,改进了错误处理方式,通过不重新抛出来减少重复信息: 未捕获的错误:未被错误边界捕获的错误将调用给 window.reportError 已捕获的错误:被错误边界捕获的错误将报告将调用给... 新的函数组件将不再需要forwardRef,在未来的版本中,React 将弃用并删除forwardRef 但是传递给类的 refs 不会作为 props 传递...在开发中,当在 Strict Mode 下进行双重渲染时,useMemo和useCallback将重用第一次渲染时的结果进行第二次渲染。已经兼容Strict Mode的组件也不会发生差异。...例如在开发过程中,Strict Mode将在初始挂载时双重调用ref回调函数,以模拟当挂载的组件被 Suspense 回退替换时的情况 移除 UMD 产物 UMD 曾经被广泛使用作为一种无需构建步骤即可加载

    35010

    别太担心,你可以在Node项目中放心使用Zod模式进行数据验证

    一旦您定义了验证器,Zod可以自动推断出静态TypeScript类型。与TypeScript不同,TypeScript在编译时执行类型检查,而Zod提供运行时类型检查,为我们提供了额外的类型安全层。...需要注意的是,.email()方法只检查基本的电子邮件格式,并不会对包含可打印字符、带引号的本地部分或者包含表情符号的电子邮件标记错误。...当我们想要优雅地处理验证错误,而不让zod抛出错误时,我们可以在模式上使用.safeParse方法。...您可以在Zod中定义函数模式,如下所示 z.function(args, returnType) 它接受两个参数,第一个是输入参数,第二个参数是你期望从函数中返回的函数返回类型。...如果您的项目已经在使用TypeScript,这将特别有帮助。 Zod非常可定制和可扩展,允许您定义自定义验证规则和错误消息,以适应您的特定需求。

    83020

    JSDoc ,一个可替代 TypeScript 的方案?

    JSDoc语法具有多种用途,包括用类型注释值,为函数指定参数和返回类型,为函数提供文档和使用信息,以及类型错误等。...此外,您可以使用 @throws 指令添加函数可能抛出的错误。 改进除法函数,我们可以指定如果除数为零则返回错误,并在代码中处理这种情况。 /** * Divide two numbers....@class 关键字用于表示需要使用 new 关键字调用的函数。 @classdec 用于描述整个类。在编写类时,通过添加类型和描述来进一步完善是很重要的。...构造函数 类中创建的所有方法和变量 我们使用 @params 关键字来提供需要传递给构造函数的参数的类型和描述。类中的方法与函数的类型方式相同,这在前一节中已经介绍过。...JSDoc在以下情况下特别有用:当您的Typescript编译时间/构建步骤对生产力产生相反的影响时,以及在处理遗留代码库时。

    83110

    【Vuejs】301- Vue 3.0前的 TypeScript 最佳入门实践

    因为 any可以代替任意类型,所以该方法在传入参数不是数组或者带有 length属性对象时,会抛出异常。...方法二,定义了参数类型是 Array的泛型类型,肯定会有 length属性,所以不会抛出异常。 3....有些是只在某些条件下存在,或者根本不存在。 例如给函数传入的参数对象中只有部分属性赋值了。带有可选属性的接口与普通的接口定义差不多,只是在可选属性名字定义的后面加一个 ?符号。...但是,解释器读到函数修饰符“@”的时候,后面步骤会是这样: 去调用 test函数, test函数的入口参数就是那个叫“ func”的函数; test函数被执行,入口参数的(也就是 func函数...)会被调用(执行); 换言之,修饰符带的那个函数的入口参数,就是下面的那个整个的函数。

    4.4K52

    Vue 3.0前的 TypeScript 最佳入门实践

    因为 any可以代替任意类型,所以该方法在传入参数不是数组或者带有 length属性对象时,会抛出异常。...方法二,定义了参数类型是 Array的泛型类型,肯定会有 length属性,所以不会抛出异常。 3....有些是只在某些条件下存在,或者根本不存在。 例如给函数传入的参数对象中只有部分属性赋值了。带有可选属性的接口与普通的接口定义差不多,只是在可选属性名字定义的后面加一个 ?符号。...但是,解释器读到函数修饰符“@”的时候,后面步骤会是这样: 去调用 test函数, test函数的入口参数就是那个叫“ func”的函数; test函数被执行,入口参数的(也就是 func函数...)会被调用(执行); 换言之,修饰符带的那个函数的入口参数,就是下面的那个整个的函数。

    3.5K20

    理论 | Typescript 是如何保证前端质量的

    开发目标 我们很清楚 ES6 只是 ES5 的扩展,尽管 Chrome 等浏览器已经率先实现了部分 ES6 功能,但依然需要通过 Babel 进行编译,才能对旧版的浏览器提供支持,其实我个人觉得它除了解决部分开发效率...对于直接的数据操作并没有类型检查,但当生成一个函数,并且对参数赋予类型时,便会在编译时进行类型检查,对于不符合类型要求的地方,会直接抛出错误,中止编译过程,同时我们还可以看到,它对 Javascript...然后直接使用 tsc 就可以进行编译了,更多编译参数,请参考 tsconfig.json 文档 需要特别说明的是以下几个参数 配合 webpack Typescript + Webpack 使用非常简单...变量类型系统 在 Typescript 中,声明变量时如果直接赋值,则会使用自动类型判断固定该变量的类型,例如: 如果需要声明一个变量,但不赋值,就必须给它声明一个类型,当后期使用类型不符合时会抛出错误...直接使用 ts-node 运行会发现编译不过,抛出了错误 是因为在最后我们给 helloWorld 赋予了一个 interface IHelloWorld 中不存在的 testproperty,把它删掉就可以正常编译运行了

    1K10

    TypeScript 官方手册翻译计划【十二】:类

    TypeScript 不会分析在构造器中调用的方法以检测初始化语句,因为派生类可能会重写这些方法,导致初始化成员失败。...super(); } } 在 JavaScript 中,忘记调用 super 是一个常见的错误,但 TypeScript 会在必要时给你提醒。...泛型类的静态成员永远都不能引用类的类型参数。 类的运行时 this 有个要点需要记住,那就是 TypeScript 不会改变 JavaScript 的运行时行为。...this 参数 在 TypeScript 的方法或者函数定义中,第一个参数的名字如果是 this,那么它有特殊的含义。...这种方法的利弊权衡和上面使用箭头函数的方法相反: JavaScript 的调用方可能仍然会在没有意识的情况下错误地调用类方法 只会给每个类定义分配一个函数,而不是给每个类实例分配一个函数 仍然可以通过

    2.6K10

    【TypeScript 演化史 — 第七章】映射类型和更好的字面量类型推断

    freezePoint 函数接受一个 Point 作为参数并冻结该参数,接着,向调用者返回相同的对象。然而,该对象的类型已更改为FrozenPoint,因此其属性被静态类型化为只读。...这就是为什么当试图将 42 赋值给 x 属性时,TypeScript 会出错。在运行时,分配要么抛出一个类型错误(严格模式),要么静默失败(非严格模式)。...当咱们更改 Point 时,还必须更改FrozenPoint,这很容易出错,也很烦人。 需要 freezePoint 函数。...试图更改其他位置的值会导致编译时错误。因此,推断只读类属性的字面量类型是合理的,因为它的值不会改变。...string 而不是 “GET”,则会出现编译时错误,因为无法将HTTP_GET 作为第二个参数传递给get函数: Argument of type 'string' is not assignable

    3.8K40

    一文解决现代编程语言选择困难:命令式编程

    因此在选择一门编程语言时,不能只看是否支持类型系统, 学习难度 即便编程语言是完美无瑕的,如果一位新手上船需要前期投入数月甚至是数年的精力,那么又会有多少人使用呢?...不可变性 我认为大型的面向对象程序,需要解决由于大规模可变对象间关联所导致的复杂图结构。否则在调用方法时,必须得把握并牢记该方法的功能和副作用。...简而言之,就是数据不会发生改变。例如,大多数编程语言中的字符串。字符串转为大写,并不会去改变原始的字符串,而是返回一个新的字符串。 为确保任何事情都不发生改变,不可变性对上述理念做了进一步扩展。...但使用不可为空类型并非编程默认,也并非 TypeScript 的惯用做法。 错误处理 TypeScript 中,使用抛出和捕获异常处理错误。...React 中,函数参数 props 是不可变的;而 TypeScript 中,没有内置提供适用的不可变数据结构支持。

    1.2K30
    领券