news 2026/5/4 10:38:37

TypeScript 变量声明

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
TypeScript 变量声明

TypeScript 变量声明详解

TypeScript 的变量声明方式与现代 JavaScript(ES6+)完全一致,主要使用letconstvar(不推荐)。区别在于 TypeScript 增加了静态类型注解,可以在声明时指定变量的类型,从而在编译阶段捕获错误。

1. 基本声明关键字
关键字作用域是否可重新赋值是否可重新声明推荐场景
const块级作用域不可不可常量、不会改变的值
let块级作用域不可需要重新赋值的变量
var函数作用域(或全局)不推荐(易导致 bug)
2. 声明语法与类型注解

基本格式:

// 无类型注解(依靠类型推断)letvariableName=value;// 带类型注解letvariableName:type=value;// const 同理constconstantName:type=value;
示例对比
// 1. const(推荐用于不变值)constPI:number=3.14159;// 显式类型注解constusername="Alice";// 类型推断为 string(推荐,简洁)// username = "Bob"; // 错误:const 不可重新赋值// 2. let(用于可变变量)letage:number=25;// 显式注解age=26;// OKletscore=100;// 类型推断为 numberscore=200;// OK// score = "high"; // 错误:类型不匹配// 3. var(不推荐)varoldStyle="legacy";// oldStyle = 123; // JS 中允许,但 TS 会根据首次赋值推断类型
3. 类型注解的位置与类型推断
  • 推荐优先使用类型推断:大多数情况下无需显式写类型,TS 会自动推断。
  • 显式注解的场景
    • 初始化值是nullundefined时。
    • 函数参数和返回值。
    • 复杂对象、联合类型等。
letname:string;// 声明但未初始化(必须显式类型)name="Alice";letnullable:string|null=null;// 联合类型letdata:any="anything";// 关闭类型检查(慎用)
4. 特殊声明方式
a. 解构赋值(Destructuring)
// 数组解构const[first,second]:[number,number]=[1,2];// 对象解构interfaceUser{name:string;age:number;}const{name,age}:User={name:"Bob",age:30};// 部分解构 + 重命名const{name:userName,age}:{name:string;age:number}={name:"Charlie",age:28};
b. 默认值与可选属性
functiongreet(name:string="Guest"):string{return`Hello${name}`;}greet();// "Hello Guest"greet("Dave");// "Hello Dave"
c. 展开运算符(Spread)
constdefaults={timeout:1000,retries:3};constconfig:typeofdefaults={...defaults,timeout:5000};
5. 作用域示例(let vs var)
if(true){letblockScoped="only here";// 块外不可访问varfunctionScoped="everywhere";}console.log(functionScoped);// OK// console.log(blockScoped); // 错误:未定义
6. 最佳实践建议
  1. 优先使用const,需要修改时再改用let
  2. 永远不要使用var(容易造成变量提升和作用域污染)。
  3. 大多数情况依靠类型推断,只在必要时添加显式类型。
  4. 开启严格模式strict: true),包括noImplicitAny等。
  5. 对于对象和数组,推荐使用接口或类型别名定义结构。
// 推荐:定义接口后声明变量interfacePoint{x:number;y:number;}constorigin:Point={x:0,y:0};letposition:Point={x:10,y:20};
小结:常见声明模式速查
场景推荐写法
常量字符串/数字const NAME = "Alice";
可变值let count = 0;
明确类型(复杂)let ids: number[] = [];
对象const user: { name: string; age: number } = ...或使用 interface
可能为空`let element: HTMLElement

如果您想深入了解函数参数声明类属性声明模块内声明或其他高级场景(如声明合并、声明文件.d.ts),请告诉我!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/28 1:05:16

TypeScript 接口

TypeScript 中的接口(Interface)详解 接口(interface) 是 TypeScript 中最常用、最重要的类型定义方式之一,主要用于描述对象的形状(shape),定义对象应该具有哪些属性、方法及其类型…

作者头像 李华
网站建设 2026/5/3 4:24:42

揭秘Open-AutoGLM可视化建模:如何3步完成企业级自动化流程搭建

第一章:Open-AutoGLM无代码流程设计概述Open-AutoGLM 是一款面向非技术用户与开发者的可视化流程自动化工具,基于大语言模型驱动的逻辑生成能力,实现无需编写代码即可构建复杂任务流程。通过拖拽式界面与自然语言指令解析,用户可快…

作者头像 李华
网站建设 2026/4/27 5:13:28

Open-AutoGLM指令调度黑科技:如何实现推理速度提升3倍以上?

第一章:Open-AutoGLM指令调度黑科技:实现推理加速的底层逻辑Open-AutoGLM 作为新一代开源大语言模型推理优化框架,其核心突破在于指令级动态调度机制。该机制通过重构计算图中的算子执行顺序,结合硬件感知的负载均衡策略&#xff…

作者头像 李华
网站建设 2026/5/1 13:21:51

Excalidraw Dropbox联动操作指南

Excalidraw 与 Dropbox 联动:打造轻量级可视化协作闭环 在分布式团队成为常态的今天,如何让一次头脑风暴的草图不随浏览器关闭而消失?怎样确保产品、开发、设计三方看到的是同一版架构图?这些问题背后,其实是对“轻量但…

作者头像 李华
网站建设 2026/5/1 17:17:53

Excalidraw OAuth2认证接入流程

Excalidraw OAuth2 认证接入流程 在现代远程协作日益成为常态的背景下,可视化工具早已不再是简单的绘图板,而是团队沟通、产品设计和系统架构讨论的核心载体。Excalidraw 以其独特的手绘风格和极简交互脱颖而出,被广泛用于绘制流程图、线框图…

作者头像 李华