hello TypeScript

news2025/1/3 5:58:41

在上一章节中我们介绍了typescript的产生背景,和使用typescript开发需要环境和工具,这一节我们就来感受一下typescript

一、第一个typescript程序,‘hello ts’

1. 安装TypeScript编译器

在开始编译TypeScript文件之前,需要先安装TypeScript编译器。可以使用npm安装TypeScript,命令为:

npm install -g typescript

安装完成后,可以在命令行输入tsc -v来检查TypeScript版本。

在这里插入图片描述

2. 创建TypeScript文件

在这里插入图片描述

在安装完TypeScript编译器后,需要创建一个TypeScript文件。TypeScript文件的扩展名为.ts

例如,可以创建一个叫做hello.ts的文件,并在其中编写以下代码:

function sayHello(name: string) {
  console.log("Hello, " + name);
}

let myName = "TypeScript";
sayHello(myName);

3. 编译TypeScript文件

一旦编写了TypeScript文件,接下来需要将其编译为JavaScript文件。可以使用tsc命令来进行编译,例如:

tsc hello.ts

这个命令将会在当前目录下生成一个名为hello.js的JavaScript文件。
在这里插入图片描述

4. 使用node执行hello.js文件

在这里插入图片描述
如图控制台打印出了 Hello TypeScript

二、tsconfig.json介绍

细心的伙伴可以看到我上面截图的tsconfig.json文件

tsconfig.json文件是TypeScript项目的配置文件,它可以包含各种编译选项,用来配置TypeScript编译器的行为TSConfig文件是一个JSON格式的文件,由TypeScript团队提供,并被广泛使用。TSConfig文件包含了TypeScript编译器的所有配置信息,它可以用来定义编译器将要处理哪些文件,以及如何处理这些文件。同时,它也可以用来指定生成的JavaScript文件的位置、使用的模块格式、以及其他一些特定于项目的编译器设置。

在实际开发中,常常需要为TypeScript项目创建多个TSConfig文件。每个TSConfig文件都定义了自己独立的编译选项,以便针对不同的项目需要进行配置,例如开发和测试模式、不同浏览器、不同操作系统等。TSConfig文件的使用可以大大提升项目的可维护性、可扩展性以及可重用性。

总的来说,TSConfig文件的作用包括:

  1. 配置TypeScript编译器的行为,包括指定需要编译的文件和输出目录等。

  2. 支持多种编译模式,如开发模式和生产模式。

  3. 为项目提供统一的编译选项,以确保所有开发人员都在同样的条件下编译和调试代码。

  4. 提升项目的可维护性,支持不同的模块和语法规范,以应对日益复杂的需求。

  5. 支持自定义编译器行为,满足特定项目的需求,提升开发效率和代码质量。

tsconfig.json文件的生成

我们在项目的根目录下输入

tsc --init

就可以生成tsconfig.json文件

常用配置介绍

  1. “compilerOptions”

这是tsconfig.json最重要的部分,用于设置编译器选项。关键的配置有:

  • “target”: 指定编译后的JavaScript代码的目标版本。常见的目标版本包括es5、es6、es2015、es2016和es2017等。默认值是es3。
  • “module”: 指定编译后的JavaScript模块的类型。常见的模块类型包括CommonJS、AMD、UMD、ES6模块等。默认值是CommonJS。
  • “outDir”: 指定编译后的JavaScript文件输出的目录。
  • “strict”: 启用TypeScript的严格模式,包括强类型检查和更严格的null和undefined检查。
  1. “include”

指定需要编译的文件的路径。可以使用通配符来匹配多个文件。例如:

{
  "include": [
    "src/**/*.ts"
  ]
}

表示编译所有src目录下的ts文件及其子目录下的ts文件。

  1. “exclude”

指定不需要编译的文件的路径。可以使用通配符来匹配多个文件。例如:

{
  "exclude": [
    "node_modules",
    "**/*.spec.ts"
  ]
}

表示不编译node_modules目录下的文件及以.spec.ts结尾的文件。

  1. “files”

指定需要编译的文件列表。如果指定了这个选项,include和exclude选项将被忽略。例如:

{
  "files": [
    "src/index.ts",
    "src/utils.ts"
  ]
}

表示只编译src目录下的index.ts和utils.ts文件。

  1. “extends”

可以使用extends选项来继承其他tsconfig.json文件中的配置。例如:

{
  "extends": "./base.json",
  "compilerOptions": {
    "target": "es6"
  }
}

表示继承base.json文件中的配置,并覆盖compilerOptions.target选项。

  1. “references”

可以使用references选项来将多个项目进行关联,并在编译时一起构建。例如:

{
  "references": [
    { "path": "../lib" },
    { "path": "../app" }
  ]
}

表示将当前项目与上级目录下的lib和app项目进行关联。

  1. “compileOnSave”

指定是否在保存文件时自动进行编译。默认值为false。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/671266.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LeetCode算法题---两数相加(二)

给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。 请你将两个数相加,并以相同形式返回一个表示和的链表。 你可以假设除了数字 0 之外,这两个数都不会以 0 …

Python嵌套列表处理「有问必答系列1」

1. 提问🙋 teacher,如果想把列表里的子列表,拆出来,让他们变成一个列表,可以用什么[可怜] 解答 如果你有一个列表包含子列表,你可以使用Python的extend()函数或列表推导式来实现。下面是两种方法的例子&a…

Dart 3.0 语法新特性 | switch 匹配加强

theme: cyanosis 一、 重新审视 switch 关键字 众所周知, switch 关键字用于流程控制: 可以基于一个对象进行匹配,并通过 case 关键字产生分支语句,进行不同的逻辑处理。其中有一个非常值得注意,使用者很容易忽略的一点…

Jetpack Compose —— ProgressBar

Jetpack Compose的ProgressBar是一种用户界面组件,用于向用户展示长时间操作的当前进度。ProgressBar可以有两种形式:线性和环形,这两种形式都可以通过Jetpack Compose轻松实现。 注意:从Jetpack Compose 1.0版本开始&#xff0c…

ChatGPT使用的SSE技术是什么?

在现代web应用程序中,实时通信变得越来越重要。HTTP协议的传统请求/响应模式总是需要定期进行轮询以获得最新的数据,这种方式效率低下并且浪费资源。因此,出现了一些新的通信技术,如WebSocket和SSE。但是,GPT为什么选择…

R语言学习4:比例的假设检验

一、实验目的 1. 掌握理解两个总体比例假设检验的相关概念。 2. 掌握理解两个总体比例假设检验的相关方法。 3. 熟悉R语言等语言的集成开发环境。 二、实验分析与内容 完成教材P98的第4题 在一个流行病事件中,A地区656 例病人中完全康复了474人,B地区568例病人中完全康复了…

k8s delete namespace Terminating

版本情况 kubenetes版本: v1.19.10 docker版本: v20.10.6 一、问题经过 早上发现 kubectl delete ns时, 删除namespace一直处于Terminating状态 尝试加上--force参数,执行kubectl delete ns --force,也是一样Terminating 当时Terminating截图 1、猜测…

《网络安全0-100》低层协议安全性

低层协议安全性 IP协议 对于网络层,IP协议是其中一个非常重要的协议。网络层的IP地址相当于数据链路层的Mac地址。协议字段如下,每行4字节,总共4*520字节。 IP协议安全性:IP协议不能保证数据就是从数据包中给定的源地址发出的&am…

高速 AD/DA 实验

目录 高速 AD/DA 实验 1、简介 1.1、AD9708 芯片 1.2、AD9280 芯片 2、实验任务 3、硬件设计 4、程序设计 4.1、AD/DA 顶层模块代码 4.2、创建一个 ​​​​​​​ILA IP 核 4.3、创建一个ROM IP核,将 .coe 文件保存到生成的 Rom IP 核中 4.4、DA 数据发…

人工智能基础实验报告

蒙特卡洛算法 目 录 蒙特卡洛算法 1 概述: 1 思考步骤: 1 应用: 1 特点: 2 参 考 资 料 3 概述: 蒙特卡罗法(Monte Carlo method)也称统计模拟法、统计试验法。是把概率现象作为研究对象的数值模拟方法。是按抽样调…

【操作系统】CPU调度

目录 1.什么叫调度 2.调度的目标 3.进程调度方式 4.闲逛进程 5.典型的调度算法 5.1先来先服务(FCFS)调度算法 5.2短作业优先(SJF) 调度算法 5.3优先级调度算法 5.4高响应比优先调度算法 5.5时间片轮转调度算法 5.6多级队列调度算法 5.7多级反馈队列调度算法(融合了前…

Qgis基本操作之图层符号化和标注实战

目录 前言 一、基础数据 1、公共预算收入数据简介 2、省份数据简介 二、地图标注 1、百强县公共预算收入地图标注 2、省信息标注 三、地图符号化 1、百强县公共预算收入符号化 2、省数据符号化 总结 前言 在之前的Qgis中进行Shp和Excel属性连接实现百强县公共预算空间分…

MATLAB 之 图形对象及其句柄和图形窗口与坐标轴

这里写目录标题 一、图形对象及其句柄1. 图形对象2. 图形对象句柄的使用3. 图形对象属性3.1 属性名与属性值3.2 属性的操作3.3 图形对象的公共属性 二、图形窗口与坐标轴1. 图形窗口对象2. 坐标轴对象 一、图形对象及其句柄 MATLAB 的图形系统是面向图形对象的。图形对象是 MA…

Redis新功能

Redis 新功能 ACL 参考官网:https://redis.io/topics/acl 基本介绍 1、Redis ACL 是Access Control List(访问控制列表)的缩写,该功能根据可以执行的命令和可以访问的键来限制某些连接 2、在Redis 5 版本之前,Red…

使用python做一个批量重命名文件的小工具

🛴 放松 端午放假前的下午🙄 没事儿可做,一个准备开始弄的项目里面有大量的图片,但是名字都乱七八糟的,作为一个稍微带点强迫症的人看不下去。 既然如此,想直接重命名,可是Windows的重命名效果…

《XrayGLM:基于VisualGLM-6B微调训练对X光胸片进行医学诊断》学习分享与本地项目微调部署实践

XrayGLM据说是首个会看胸部X光片的中文多模态医学大模型,我最近也是因为关注这个所以就找时间学习了一下,顺便把学习资料对应记录分享一下。 官方提供了开源的项目,地址在这里,如下所示: 最近,通用领域的大…

MySQL - 第6节 - MySQL表的增删查改

1.MySQL表的增删查改概述 • 表的增删查改简称CRUD:Create(新增),Retrieve(查找),Update(修改),Delete(删除)。 • CRUD的操作对象是对…

抖音小店有哪些常见扣分原因?如何避免在抖音小店中被扣分?

抖音小店现在已经成为了很多商家的首选电商平台,但是在使用抖音小店的过程中,也会出现一些扣分的情况。接下来,四川不若与众将为大家介绍抖音小店扣分的原因和避免办法。 一、抖音小店扣分原因 1. 服务不到位:商家没有及时回复用户…

2023-01-06 VMWare桥接网络配置.md

VMWare16 桥接网络配置 一 环境清单 VMWare 16虚拟机:Centos7宿主机:Windows 10 二 配置过程 查看宿主机的IP相关信息 ipconfig -all 配置虚拟网络编辑器 2.1 打开VMware Workstation Pro,点击左上角编辑-->虚拟网络编辑器 2.2 点击更改配…

CRM商机管理:提升客户体验和销售效率

如何利用CRM系统提升商机管理? 花点时间思考一下你的企业管理商机的方法,是否有以下情况: ● 不知道渠道中的商机是否可行。 ● 不知道应该关注哪些商机。 ● 花了几个小时或几天的时间来跟进商机。 ● 不知道赢得商机与失去商机的比例。 如…