Typescript 哲学 - ts模块使用最佳实践

ts的作用域 默认是全局(global),这也是为什么在 两个ts文件声明同一个变量报错变量名冲突,解决方法是使某个文件以模块的形式存在(文件顶层使用 export 、import )

In TypeScript, just as in ECMAScript 2015, any file containing a top-level import or export is considered a module.

模块的作用:

隔离代码的作用域范围、较好的代码组织形式

组织代码的几种形式:

一、namespace

顶层没有 export 那么该namespce全局都可见

1、(可以通过 /// 语法分割为多个文件)

2、 支持自定义名字 import polygons = Shapes.Polygons;

二、 declare module

ts 的全局作用域的应用场景

比如 jquery 库使用js写的,引入 jquery依赖时 全局便有了一个全局变量 $ ,这时可以声明一个 全局的 变量声明对 其访问的属性进行控制

declare global {} 只能在模块中使用

在 TypeScript 中,declare global 语法可以在模块中添加全局声明。这意味着,尽管这个文件被视为一个模块(因为它有 export {} 语句),但是 declare global 块中的内容会被视为全局声明。

相关推荐
Ryan今天学习了吗15 分钟前
前端知识体系总结-前端工程化(Webpack篇)
前端·面试·前端工程化
Ryan今天学习了吗16 分钟前
前端知识体系总结-前端工程化(Babel篇)
前端·面试·前端工程化
GISer_Jing17 分钟前
基于 OpenClaw 构建 博客自动撰写 Agent
前端·aigc·ai写作
潜水豆20 分钟前
基于cursor 的自用专家系统v0.2
前端
Ryan今天学习了吗21 分钟前
前端知识体系总结-前端工程化(Vite篇)
前端·面试·前端工程化
Neon120422 分钟前
WKWebView 中 iframe 无法监听原生 JSBridge 回调的完整分析
前端
用户81686947472525 分钟前
Chrome 插件开发入门
前端
_Eleven27 分钟前
前端布局指南
前端·css
Gogo112130 分钟前
JavaScript 里的“空”:Null 与 Undefined 的终极指南
javascript
一枚前端小姐姐33 分钟前
Vue3 + Vite 从零搭建项目,超详细入门指南
前端·vue.js