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 编译器以一种特定的方式解释该变量的类型。如果类型断言错误,将可能导致程序运行错误。

相关推荐
爱吃大芒果8 小时前
从零搭建完整 HarmonyOS 应用实战教程
华为·typescript·harmonyos
烛衔溟12 小时前
TypeScript 中的类基础
javascript·ubuntu·typescript
烛衔溟16 小时前
TypeScript 类实现接口
linux·ubuntu·typescript
在繁华处18 小时前
从零搭建轻灵:一个 TypeScript CLI Agent 框架的诞生
前端·javascript·typescript
chushiyunen2 天前
typescript笔记、ts笔记、npx命令
javascript·笔记·typescript
yqcoder2 天前
TypeScript 进阶:如何精准获取对象的所有 Key?
javascript·ubuntu·typescript
程序员mine2 天前
我开发了一个 Obsidian 插件「带宠物的锁屏」—— 保护我的笔记隐私
typescript
晓杰'3 天前
Balatro后端进阶(1):自定义NestJS WebSocket Adapter实现消息拦截
后端·websocket·typescript·node.js·游戏开发·nestjs·wsadapter
励志前端小黑哥3 天前
开发了一个APP,我叫它minebook-hot-server -- 本地服务端口管理工具
rust·typescript
小杍随笔4 天前
【iNovel 前端架构深度解析:基于 Vue 3 + TypeScript + Tauri 的跨端小说写作工具】
前端·架构·typescript