编写 Runtime 插件
Farm 运行时插件是一个纯 JavaScript 对象,它定义了一组钩子来增强 Farm 运行时。 例子:
上面是一个支持 Farm 的 HMR 的运行时插件。 要点:
- 运行时插件入口文件应该
导出
定义一组钩子的默认对象。 例如导出默认 <Plugin>{/*...*/}
- 需要
name
来标识插件,确保name
是唯一的 hook
是在导出对象中定义的方法。
有关上述示例的完整实现,请参阅 @farmfe/runtime-plugin-hmr。
注意事项
您应该使您的运行时插件尽可能简单。 你不应该:
- 使用node_modules中的大依赖,这会让你的 Farm 运行时插件非常大,可能会严重影响运行时性能。
- 使用
top level await
等新功能,因为这些与运行时相关的功能很难针对低级别运行时进行 polyfill。
强烈建议确保您的运行时插件尽可能小且简单。
import.meta.xxx
将被编译为 module.meta.xxx
,您可以在运行时插件中向 module.meta
添加值来增强 import.meta
。 例如, module.meta.hot = createHotContext(module.id, hmrClient)
使 import.meta.hot
可用。
惯例
Farm 运行时插件名称应以 farm-runtime-plugin
为前缀,例如 farm-runtime-plugin-xxx
。
plugin.name
和 package name
(仅当您将插件发布为包时)都应该加上前缀。
使用 Runtime 插件
使用 compilation.runtime.plugins
为您的项目配置运行时插件:
您可以通过 3 种方式配置运行时插件项:
相对路径
:相对于root
的路径,例如./src/my-plugin1.ts
将尝试从<root>/src/my-plugin1.ts
加载插件。绝对路径
:例如/root/project/src/my-plugin2.ts
。 (在 Windows 上绝对路径应为C:\project\src\my-plugin2.ts
)。包名称
:Farm将尝试从node_modules
加载此包,例如@scope/plugin-package-from-node-modules
。
编写 Runtime 插件
Farm支持直接加载.ts
文件,因此您可以直接在runtime.plugins
中配置一个.ts
文件(或条目为ts
文件的包)。
创建插件
正如我们上面提到的,Farm 运行时插件是一个纯 JavaScript 对象,它定义了一组钩子,您只需创建一个 ts 文件,例如:
然后在导出的对象中定义您需要的hooks:
定义插件
配置您在 runtime.plugins
中创建的插件:
然后启动Farm项目,这个插件会在编译时注入输出资源的 runtime 中。
发布插件(可选)
您可以将运行时插件发布到 npm 注册表以共享您的 Farm 运行时插件。 只需创建一个 package.json
,例如:
You can just export ts
file using "main": "src/index.ts"
.
运行时插件钩子
请参阅运行时插件 API