TypeScript 第三节:变量声明

一、命名规则

TypeScript 变量的命名规则与 JavaScript 一致,具体如下:

  1. 变量名必须以字母、下划线或美元符号($)开头;
  2. 变量名可以包含字母、数字、下划线或美元符号($);
  3. 变量名区分大小写;
  4. 变量名不能与 TypeScript 的关键字相同(例如:let、const、class、function 等);
  5. 变量名应该具有描述性,能够清晰地表示变量的含义。

一些推荐的命名规范:

  1. 使用小写字母和驼峰命名规则(例如:firstName);
  2. 对于常量,使用全大写字母和下划线命名规则(例如:MAX_SIZE);
  3. 避免使用单个字符作为变量名(例如:x、y、i 等),除非变量的作用范围非常小。

二、4种声明变量的类型及初始值:

1、var 变量名 : 类型 = 值;

TypeScript 复制代码
var uname:string = "Runoob";

2、var 变量名 : 类型;

// 声明变量的类型,但没有初始值,变量值会设置为 undefined:

TypeScript 复制代码
var uname:string;

3、 var 变量名 = 值;

// 声明变量并初始值,但不设置类型,该变量可以是任意类型:

TypeScript 复制代码
var uname = "Runoob";

4、var 变量名;

// 声明变量没有设置类型和初始值,类型可以是任意类型,默认初始值为 undefined:

TypeScript 复制代码
var uname;

三、类型断言(Type Assertion)

TypeScript类型断言(Type Assertion)是指在编译阶段确定变量的数据类型,以确保代码的正确性。在TypeScript中,有两种类型断言的方式:尖括号语法和as语法。

1、尖括号语法

<类型>值

使用尖括号语法的类型断言,需要把待转换的变量放在尖括号内并指定类型。

typescript 复制代码
let someValue: any = "hello world";
let strLength: number = (<string>someValue).length;

2、as语法

值 as 类型

使用as语法的类型断言,需要把待转换的变量放在变量名后面,并用as操作符指定类型。

typescript 复制代码
let someValue: any = "hello world";
let strLength: number = (someValue as string).length;

注意:

在TypeScript中,as语法更加常用,因为它既可以用于类型断言,也可以用于类型别名中的类型指定。
两种形式的作用是相同的,可以根据自己喜欢的风格来使用。

需要注意的是,在使用类型断言时应该尽量避免类型转换错误,因为类型断言并不会改变变量的实际类型,而只是告诉 TypeScript 编译器以一种特定的方式解释该变量的类型。如果类型断言错误,将可能导致程序运行错误。

相关推荐
退休倒计时16 小时前
【每日一题】LeetCode 15. 三数之和 TypeScript
数据结构·算法·leetcode·typescript
FlyWIHTSKY17 小时前
JavaScript 和 TypeScript 分别是什么,可以相互写吗
javascript·ubuntu·typescript
云水一下18 小时前
TypeScript 从零基础到精通(七):从配置到全栈项目落地
前端·javascript·typescript
Aolith19 小时前
从 Pinia 到 Zustand:我在 React 里复刻了一套用户状态管理
前端·react.js·typescript
Aolith19 小时前
Express + TypeScript 下写 JWT 中间件,我踩了三个坑
typescript·node.js·express
夜雪闻竹1 天前
测试策略:单元测试 + 集成测试怎么写
typescript·单元测试·集成测试·chatcrystal
JieE2122 天前
Bun + TypeScript:下一代 JavaScript 全栈开发的正确打开方式
typescript·全栈·bun
GuWenyue2 天前
告别JS类型坑!Ts为什么在ai时代逐渐成为"第一"语言
前端·算法·typescript
kisshyshy2 天前
告别 Node 噩梦?用 Bun + TypeScript 像写诗一样调用大模型
前端·typescript
悟空瞎说2 天前
吃透 TypeScript 6.0 五大实用新特性,顺带前瞻 TS7.0,附全代码示例
typescript