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

相关推荐
FrontAI11 小时前
深入浅出 LangChain —— 第三章:模型抽象层
前端·人工智能·typescript·langchain·ai agent
凰轮12 小时前
TypeScript 知识点总结
前端·javascript·typescript
|晴 天|12 小时前
Element Plus 组件库实战技巧与踩坑记录
前端·javascript·vue.js·typescript
donecoding13 小时前
类型与语法的“直觉对齐”:TS 切入的 Go 语言初体验
前端·typescript·go
军军君0116 小时前
数字孪生监控大屏实战模板:商圈大数据监控
前端·javascript·vue.js·typescript·前端框架·echarts·three
落魄江湖行17 小时前
进阶篇五 Nuxt4 部署方案:从开发到生产
前端·vue.js·typescript·nuxt4
幺风1 天前
Claude Code 源码分析 — 核心对话循环
typescript·ai编程
木心术11 天前
TypeScript实战进阶:从基础类型到高级类型编程
javascript·ubuntu·typescript
落魄江湖行2 天前
进阶篇四 Nuxt4 Server Routes:写后端 API
前端·vue.js·typescript·nuxt4
落魄江湖行2 天前
进阶篇三 Nuxt4 Nitro 引擎:Nuxt 的服务端核心
前端·vue.js·typescript·nuxt4