乐闻世界logo
搜索文章和话题

How to expose a class to the global scope with esbuild?

5 个月前提问
5 个月前修改
浏览次数12

1个答案

1

当需要在全局范围内暴露一个类,例如在一个Web项目中使用esbuild进行构建,你可以通过将该类添加到全局对象,如window(在浏览器环境中)上,从而使它在全局可用。以下是具体的步骤和示例:

步骤 1: 创建一个类

首先,我们需要定义一个类,这个类将会被暴露到全局范围。例如,创建一个Person类。

javascript
// src/Person.js export class Person { constructor(name, age) { this.name = name; this.age = age; } introduce() { return `My name is ${this.name} and I am ${this.age} years old.`; } }

步骤 2: 创建一个入口文件

在入口文件中,导入Person类并将其添加到全局对象window上。

javascript
// src/index.js import { Person } from './Person.js'; window.Person = Person;

这样,Person类就可以在全局范围内通过window.Person访问。

步骤 3: 使用 esbuild 构建项目

接下来,使用esbuild来构建项目。你可以在命令行中运行esbuild,或者使用一个构建脚本。

bash
esbuild src/index.js --bundle --outfile=dist/bundle.js

这个命令会将src/index.js作为入口文件,打包所有依赖,并输出到dist/bundle.js

步骤 4: 在HTML中引用构建后的文件

最后,在HTML文件中引入构建后的JavaScript文件。

html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Test Page</title> </head> <body> <script src="dist/bundle.js"></script> <script> const john = new Person('John', 30); console.log(john.introduce()); // 输出: My name is John and I am 30 years old. </script> </body> </html>

小结

通过这种方式,我们使用esbuildPerson类打包并暴露到全局对象上,使得在任何地方都可以通过全局变量访问Person类。这种方法在开发库或者是进行某些特定项目构建时非常有用。请注意,过多地使用全局变量可能会导致代码难以维护和理解,因此建议谨慎使用。

2024年8月10日 01:06 回复

你的答案