首页
学习
活动
专区
圈层
工具
发布

TypeScript基本语法使用

前言 此文档是根据b站视频所记 浏览器是不认识ts语言的,写的ts代码也会编译成js让浏览器识别 ts官网:在线写ts 安装 npm i typescript -g 1.类型判断 let str = "...result = numArr.find(item => item > 2); result * 5; //程序推断item可能会是undefined //正确(在自己十分确定该业务不会出现undefined使用...= 2; //正确 let v5: 1 | 2 | 3 = "2"; //错误 5.数组、元组、枚举 //数组 let arr1 = [1, 2, 3, "4"]; //正确,但在实际开发中不建议这样使用...console.log(f); //输出 20楠笙12,3,4,5 7.接口 //正常定义对象类型 const obj = { name: "xiaomin", age: 15, }; //使用接口...interface obj { name: string; age: number; }; //使用该接口来定义对象 const obj: obj = { name: "a", age

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

    使用 TypeScript 开发你的项目

    JavaScript 是动态类型的,只能在 runtime 时进行类型检查;同时它也给重构大型项目带来了的困扰,在一定程度上,它是不「易读」的。而 TypeScript 能够很好的解决上述问题。 ?...TypeScript 最早是在 2012 年十月份由微软开源在 GitHub 上,它是 JavaScript 的一个超集,除了能让我们使用 ES Future 的各种语法外,还提供如 Enum、Tuple...、Generics 等的新语法。...不同于 JSDoc,TypeScript 提供的类型声明和模块接口形成了文档的形状,提供程序的行为提示,并在编译时会校验程序的正确性。 改动下上个例子: ? 当然,对大型项目来说,这可能要复杂的多。...现在来使用它: const func: (arg: number) => string = String // 在这里 String 是一个方法 复制代码 在实际应用中,并不会这么用,因为 TypeScript

    1.5K20

    使用Jest测试原生TypeScript项目

    再次列举下,这个项目中所需要搭建配置的工具。...Jest+TS入门 第一个问题,我项目都是TS写的,自然会有 import 这样的语法怎么办?...通过官网的Getting started 我们可以在最下方找到 ts-jest 不难理解,我们需要配的其实就是jest加载到什么样类型的文件,使用什么预处理来处理文件。...如果是js文件我通过babel-jest处理,css则使用jest-css-modules。假如没有这些配置,那import了你的库,库里有引入了高特性的js文件,或者css文件就会编译报错。...本文没有过多得介绍Jest的用法或者语法,希望可以给不知道如何做测试的朋友们一点方向,自己去尝试找到适合自己项目的才是最好的。 刚刚开始可能很难,无从下手,成本很大。

    3.2K60

    使用 TypeScript 开发你的项目

    JavaScript 是动态类型的,只能在 runtime 时进行类型检查;同时它也给重构大型项目带来了的困扰,在一定程度上,它是不「易读」的。而 TypeScript 能够很好的解决上述问题。...TypeScript 最早是在 2012 年十月份由微软开源在 GitHub 上,它是 JavaScript 的一个超集,除了能让我们使用 ES Future 的各种语法外,还提供如 Enum、Tuple...、Generics 等的新语法。...不同于 JSDoc,TypeScript 提供的类型声明和模块接口形成了文档的形状,提供程序的行为提示,并在编译时会校验程序的正确性。 改动下上个例子: 当然,对大型项目来说,这可能要复杂的多。...现在来使用它: const func: (arg: number) => string = String // 在这里 String 是一个方法 在实际应用中,并不会这么用,因为 TypeScript

    22010

    使用VisualGDB将Keil项目导入VisualStudio

    前言 本教程展示了如何使用新的Keil项目导入器将Keil ARM项目自动转换为使用MSBuild和GCC构建的VisualGDB项目。在开始之前,安装VisualGDB 5.3或更高版本。...3、选择“自动导入不同格式的项目->导入现有Keil项目”。然后指定位于前面的.uvprojx文件 ?...6、按“Finish”生成项目。VisualGDB将自动导入源文件,包括Keil项目中的目录和预处理器宏。...这是因为项目包含了一个特殊的数据部分,该部分需要放入QSPI内存中,而Keil导入器不能自动转换它。...12、解决这个问题的一种方法是使用VisualGDB项目属性的附加内存页面,让VisualGDB自动编辑链接器脚本,但是由于ST演示项目已经包含了正确格式的GCC链接器脚本,我们可以简单地将VisualGDB

    1.8K20

    项目中可以使用的TypeScript优化

    构造状态的联合类型 在项目中,难免会遇到一些场景需要定义状态对象,比如想表示一个页面的状态,可能会定义下面这样的状态 const PageState = { Loading: 0, Normal...: 1, Error: 2, };  然后我们的数据源可能会使用某个字段来引用它,比如 const pageData = { //......| 2 }; const PageState = {...} as const type TypeRestfulMethod = T[keyof T];  as const 是TS的一种语法...,让编译器知道变量的类型 但我们其实不希望每次使用JSON.parse都手动的去加一个类型断言,毕竟有的时候写类型文件和使用方法的不是同一个人,我们还是希望能写一个接口来统一推断,所以我们可以这样写..., }; const str: json = JSON.stringify(role); const x = JSON.parse(str); 为配置文件定义类型 一般情况下,我们的项目都会有多个环境的配置文件

    45310

    如何在 Vue TypeScript 项目使用 emits 事件

    然后,消息有效载荷存储在 messageFromChild 引用中,该引用会自动更新模板以显示来自子组件的消息。 简单吧?这展示了你如何在Vue中使组件“相互通信”。...如何在Typescript中正确地使用类型推断 使用emits的一个“缺点”是,当你发出一个自定义事件时,你不一定知道子组件会发出什么。这种不确定性可能会导致数据类型和运行时错误的潜在问题。...幸运的是,Vue 3的Composition API与TypeScript结合提供了一个非常强大的解决方案来解决这个问题。...让我们探索如何使用Vue 3的Composition API和script setup正确地使用TypeScript来输入emits。...子组件(使用TypeScript): Send Data to Parent </template

    1.1K10

    关于项目中是否使用Typescript的疑惑与解答

    如果你公司的项目目前只支持 JS,也没有关系,只需要加一个 ts-loader 或者 awesome-typescript-loader 就能提供 TypeScript 支持,TS 可以和 JS 共存哦...听说 TS 只适合大型项目? 错,只要是有 bug 的 JS 项目,都可以用 TS 替代 JS 从而减少 bug。 所以无论是小项目还是大项目,都有必要使用 TS。 万一过几年 TS 不火了呢?...因为目前前端三大框架全都支持 TS 了: Angular 很早就支持 TypeScript 了,而且还把 JS 从自己的名字里去掉了:AngluarJS -> Angular。...No No No,TS 里面包含了 JS 的所有语法,所以你在用 TS 的时候,实际上还是在用 JS。 也就是说 JS 的魂还在,我们只是不再单独使用 JS 了。...结论 快点学 TypeScript 吧,它很快就是一线互联网公司面试加分项甚至必备项了。

    1.7K20

    初次在Vue项目使用TypeScript,需要做什么

    原文 如何使用 AlloyTeam 提供了一套全面的EsLint配置规范,适用于 React/Vue/Typescript 项目,并且可以在此基础上自定义规则。...,提供了类型定义文件(*.d.ts),开发者编写类型定义文件发布到npm上,当使用者需要在 TypeScript 项目中使用该库时,可以另外下载这个包,让JS库能够在 TypeScript 项目中运行。...如果我们想要在 TypeScript 项目中使用,还需要另外下载 @tyeps/md5,在该文件夹的index.d.ts中可以看到为 md5 定义的类型。...是如何识别 *.d.ts TypeScript 在项目编译时会全局自动识别 *.d.ts文件,我们需要做的就是编写 *.d.ts,然后 TypeScript 会将这些编写的类型定义注入到全局提供使用。...在导入ts文件时,不需要加 .ts 后缀 为项目定义全局变量后无法正常使用,重新跑一遍服务器(我就碰到过...)

    6.9K40
    领券