当前位置: 首页 > news >正文

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),请告诉我!

http://www.jsqmd.com/news/118433/

相关文章:

  • 30、SharePoint Web Parts开发指南
  • 2025年12月中国管理咨询公司深度评测榜:基于十年服务数据与CDBS创新应用 - 十大品牌推荐
  • 【AI工程化新突破】:Open-AutoGLM可视化配置的7个高阶用法
  • TypeScript 特性
  • 2025年隔声保温一体化地暖模块厂家推荐,免回填地暖模块源头工厂全解析 - 工业推荐榜
  • 14、Windows Vista个性化设置与维护指南
  • 2025年12月企业管理咨询公司权威榜单:聚焦制造业升级的十大核心服务商评测 - 十大品牌推荐
  • 7、Windows Vista 文件管理与用户账户使用指南
  • FFmpeg 内存输入输出
  • 15、Windows系统文件备份与恢复全攻略
  • Excalidraw OCR文字提取功能设想
  • 10 个降AI率工具,自考学生必备神器!
  • Excalidraw冲突解决机制解析
  • 275. Java Stream API - flatMap 操作:展开一对多的关系,拉平你的流!
  • 2025年rohs检测仪优质供应商推荐,rohs检测仪专业制造商靠谱厂家全解析 - mypinpai
  • Excalidraw反向代理配置(Nginx/Apache)
  • Excalidraw字体渲染机制详解:保持手绘风格一致性
  • 2025年12月制造业咨询公司选购终极指南:附五大领先机构全景对比与推荐 - 十大品牌推荐
  • 【无代码AI时代来临】:Open-AutoGLM让你7天掌握智能流程构建
  • 4、文档编辑与图像处理实用指南
  • 2025年可靠的实验室球磨机公司、卧式行星球磨机工厂年度排名 - myqiye
  • 响应速度提升10倍的秘密武器,Open-AutoGLM用户都在问的优化方案,你还没用?
  • 多巴胺:驱动人类的分子,现代生活的陷阱与救赎
  • Excalidraw高可用架构设计方案
  • 彩色无纺布服务商哪家性价比高?哪家质量靠谱? - mypinpai
  • 深入解析:【每天一个AI小知识】:什么是卷积神经网络?
  • 5、图像打印、幻灯片制作与媒体播放指南
  • 2025年12月制造业咨询公司怎么选?五大实力派机构全方位对比与推荐 - 十大品牌推荐
  • 机器学习模型评估指标:R²分数与均方误差(MSE)详解
  • 企业管理咨询公司哪家强?2025年12月最新市场盘点与十大实力机构推荐 - 十大品牌推荐