TypeScript的静态类型检查,在js中经常会遇到的困扰

静态类型检查

在代码运⾏前进⾏检查,发现代码的错误或不合理之处,减⼩运⾏时出现异常的⼏率,简⾔之就是把运⾏时的错误前置。

  • TypeScript 和核⼼就是静态类型检查,将js的弱语言变成【强语言】(类似于c先给变量定义个数据类型在调用)。
  • 同样的功能,TypeScript的代码量要⼤于JavaScript,但由于TypeScript的代码结构更加清晰,在后期代码的维护尤其大型项目中TypeScript却胜于JavaScript。

在js中经常遇到的困扰

  1. 不同数据类型的赋值或调用。
  2. 存在明显的逻辑漏洞。
  3. 访问不存在的属性。
  4. api方法的拼写错误。

1. 不同数据类型的赋值或调用

  • 在js中这样是可行的
  • 在ts中会报错提示不能将类型"number"分配给类型"string"类型 "String" 没有调用签名
js 复制代码
let welcome = 'hello'
weclome = 123
welcome()

2. 存在明显的逻辑漏洞

  • 在js中不会报错,但是else if内的代码快永远不会执行到
  • 在ts中会报错提示此比较似乎是无意的,因为类型""奇数""和""偶数""没有重叠
js 复制代码
const str = Date.now() % 2 ? '奇数' : '偶数'
if (str !== '奇数') {
    alert('hello')
} else if (str === '偶数') {
    alert('world')
}

3. 访问不存在的属性

  • 在js中可以访问到obj的heigth属性值为undefined
  • 在ts中会报错提示属性"heigth"在类型"{ width: number; height: number; }"上不存在。你是否指的是"height"并能一键修复更改为正确的属性名
js 复制代码
const obj = { width: 10, height: 15 };
const area = obj.width * obj.heigth;

4. api方法的拼写错误

  • 在js中编写代码时不会报错,但执行代码时会报错str.toUperCase is not a function
  • 在ts中编写代码时就会报错提示属性"toUperCase"在类型""hello,world""上不存在。你是否指的是"toUpperCase"并能一键修复更改为正确的属性名
js 复制代码
const message = 'hello,world'
message.toUperCase()
相关推荐
C澒6 分钟前
IntelliPro 产研协作平台:基于 AI Agent 的低代码智能化配置方案设计与实现
前端·低代码·ai编程
一袋米扛几楼9816 分钟前
【Git】规范化协作:详解 GitHub 工作流中的 Issue、Branch 与 Pull Request 最佳实践
前端·git·github·issue
网络点点滴29 分钟前
前端与后端的区别与联系
前端
yqcoder31 分钟前
JavaScript 柯里化:把“大餐”拆成“小炒”的艺术
开发语言·javascript·ecmascript
每天吃饭的羊37 分钟前
JSZip的使用
开发语言·javascript
EnCi Zheng1 小时前
M5-markconv自定义CSS样式指南 [特殊字符]
前端·css·python
kyriewen1 小时前
你的网页慢,用户不说直接走——前端性能监控教你“读心术”
前端·性能优化·监控
广州华水科技1 小时前
北斗GNSS变形监测在大坝安全监测中的应用与优势分析
前端
前端老石人1 小时前
前端开发中的 URL 完全指南
开发语言·前端·javascript·css·html
CAE虚拟与现实1 小时前
五一假期闲来无事,来个前段、后端的说明吧
前端·后端·vtk·three.js·前后端