项目实战 TS
项目实战 TS
通用技巧
新手先 any 再填坑,老手先定义数据结构写逻辑
遇到新场景,没把握快速,先用 any 再填坑,填坑的过程也是 TS 技能满满提升的过程。
TS 发现潜在问题
1)复杂逻辑,JS 一口气写完,调试没找到毛病,加上 TS 可以找到。
2)提测质量,提测前建议 review 一下,为避免枯燥可以完善下 TS 的使用。
- 提前定义好 TS,优势明显,有智能提示。
实用技巧
[1]公共数据结构,不想在每个文件中引来引去
- 编辑 tsconfig.json 的 include 字段,引入该 ts 文件。
[2]声明语句,声明全局对象,扩展全局对象 windows 的类型,以添加一个名为 add 的方法,接受两个数字类型的参数,返回一个数字类型的结果。
优点:
这种声明帮助 TS 开发中进行类型检查,确保你在调用 window.add 方法时传递正确类型的参数,并且能够正确处理返回值。
开发一些需要扩展全局对象功能的情况下,特别有用,
缺点:
- 但需要小心确保不会与现有的全局变量或方法发生冲突。
注意:
- 不会进行类型检查,而且 TypeScript 编译器也不会对此进行警告或错误提示。
这就提现了 TS 的优势:
在 TS 中使用 window.add 时,编译器会进行类型检查,确保你传递正确类型的参数,并能正确处理返回值。
JS 是动态类型语言,不会进行静态类型检查;因此,虽然可以在 JS 中给 window 对象添加新的属性或方法,但是编译器不会对这些扩展进行类型检查,需要自行确保。
通过 TS 的类型声明,可以获得更严格的类型检查,而 JS 则更灵活但不会进行类型检查。
代码
// 利用 interface 重复声明 扩展 window,该文件需要配置到 tsconfig.json 中的 includes 字段
declare interface Window {
add(a: number, b: number): number;
}
// 声明全局变量
declare const wx: any;
// 全局扩展
export class Observable<T> {
// ... still no implementation ...
}
declare global {
interface Array<T> {
toObservable(): Observable<T>;
}
}
// 使用
[].toObservable();
我的实践
tsconfig.json
{
"include": ["xxx1", "xxx2", "src/test.ts"],
}
src/test.ts
declare interface Window {
add(a: number, b: number): number;
}
使用:
test.vue
<template> </template>
<script>
const calculate = () => {
// 使用 inject 访问全局的 window 对象
window.add = (a, b) => a + b;
if (window) {
console.log(window.add(3, 4)); // 调用全局的 add 方法,输出: 7
}
};
</script>

参考链接
项目实战 TS的更多相关文章
- 【无私分享:ASP.NET CORE 项目实战(第八章)】读取配置文件(二) 读取自定义配置文件
目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 我们在 读取配置文件(一) appsettings.json 中介绍了,如何读取appsettings.json. 但随之产生 ...
- 【无私分享:ASP.NET CORE 项目实战(第六章)】读取配置文件(一) appsettings.json
目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 在我们之前的Asp.net mvc 开发中,一提到配置文件,我们不由的想到 web.config 和 app.config,在 ...
- SaltStack项目实战(六)
SaltStack项目实战 系统架构图 一.初始化 1.salt环境配置,定义基础环境.生产环境(base.prod) vim /etc/salt/master 修改file_roots file_r ...
- 浅谈 Angular 项目实战
为什么使用 Angular 我不是 Angular 的布道者,但如今痴迷 Angular,使用 Angular 做项目让我有一种兴奋感.目前的三大主流前端框架都研究过,博客中也有三者的相关教程,最早接 ...
- 机器学习_线性回归和逻辑回归_案例实战:Python实现逻辑回归与梯度下降策略_项目实战:使用逻辑回归判断信用卡欺诈检测
线性回归: 注:为偏置项,这一项的x的值假设为[1,1,1,1,1....] 注:为使似然函数越大,则需要最小二乘法函数越小越好 线性回归中为什么选用平方和作为误差函数?假设模型结果与测量值 误差满足 ...
- 让你的项目使用Ts吧
推荐在这里阅读 9012年都过半了,还不会用ts你就out了 why ? 三大框架angular2以后的版本完全是用ts开发的, vue对ts的支持也越来越好, React也有TSX组件 还在犹豫什么 ...
- Net core项目实战篇01---EFCore CodeFirs For Mysql 数据库初始化
从今天开始我们用Net Core进行项目实战,采用微服务构架,因此你会看到我各模块开始都是用的web api.项目中的代码直接可以复制.费话不多说,现在就来跟我一起开始吧! 1.打开VS2017—&g ...
- miniFTP项目实战六
项目简介: 在Linux环境下用C语言开发的Vsftpd的简化版本,拥有部分Vsftpd功能和相同的FTP协议,系统的主要架构采用多进程模型,每当有一个新的客户连接到达,主进程就会派生出一个ftp服务 ...
- Asp.Net Core 项目实战之权限管理系统(4) 依赖注入、仓储、服务的多项目分层实现
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- 给缺少Python项目实战经验的人
我们在学习过程中最容易犯的一个错误就是:看的多动手的少,特别是对于一些项目的开发学习就更少了! 没有一个完整的项目开发过程,是不会对整个开发流程以及理论知识有牢固的认知的,对于怎样将所学的理论知识应用 ...
随机推荐
- 抖音技术分享:飞鸽IM桌面端基于Rust语言进行重构的技术选型和实践总结
本文由ELab团队公众号授权发布,原题<Rust语言在IM客户端的实践>,来自抖音电商前端团队的分享,本文有修订和改动. 1.引言 本文将介绍飞鸽IM前端团队如何结合Rust对飞鸽客户端接 ...
- 开源商业化 Sealos 如何做到月入 160万
去年我写了一篇也是讲开源商业化的文章,当时是月入 30 万,一年过去了,我们整整涨了 5 倍多.本文理论结合实践,比较干货,希望对大家有帮助. 我们的现状,谁在给我们付钱 第一,开发者,我们已经近 2 ...
- 第三章 消息摘要算法--MD5--SHA--MAC
6.1.MD5 推荐使用CC(即Commons Codec)实现 虽然已被破解,但是仍旧广泛用于注册登录模块与验证下载的文件的完整性 可以自己写一个注册登录模块:自己下载一个MD5加密的文件,然后通过 ...
- nginx详细参数配置(史上最全)
Nginx (engine x) 是一个轻量级高性能的HTTP和反向代理服务器,同时也是一个通用 代理服务器 (TCP/UDP/IMAP/POP3/SMTP),最初由俄罗斯人Igor Sysoev编写 ...
- .NET 数据拷贝方案选择
应用中我们经常使用到数据的复制,在.NET中有多种方式可以实现复制数据或对象.选择哪种方式通.是浅拷贝还是深拷贝,取决于对象的复杂性.数据量以及具体需求场景. 1. MemberwiseClone拷贝 ...
- C语言实现高阶阶乘(1000的阶乘C语言实现)
由于C语言的变量的大小的限制,使用已有变量无法保存阶乘结果,所以使用数组保存结果,从而使得无法保存的结果得以保存. #include <stdio.h> void Print_Factor ...
- InfluxDB UI 设置保留策略
InfluxDB UI 设置保留策略 创建Bucket时设置保留策略 在InfluxDB 2.x的UI中创建Bucket时,你可以直接设置其保留策略.以下是一个基本的步骤指南: 登录到InfluxDB ...
- CMW500 Bluetooth信令测试
一.简介 R&SCMW500宽带无线通信测试仪是适用于射频集成和协议开发的通用测试平台,其内部集成RF功率计和带List模式的CW发生器,可以完成无线设备的快速校准:同时还集成了矢量信号分析仪 ...
- RocketMQ实战—7.生产集群部署和生产参数
大纲 1.RocketMQ生产集群部署和生产参数分析 2.RocketMQ生产集群10wTPS压测 3.RocketMQ生产级故障案例 1.RocketMQ生产集群部署和生产参数分析 (1)服务器数量 ...
- THUWC2025 游记
Day -C 先进入金国大臣面积群,然后发现 xyf 又在行联考学生群故事. Day -1 早上赶飞机进京.飞机上启动钢丝.到达大兴机场之后坐火车前往北京西站,然后坐地铁到海淀黄庄.非常饿,但是决定先 ...