"use strict";(self.webpackChunkfes_js=self.webpackChunkfes_js||[]).push([[861],{4794:(n,s,a)=>{a.r(s),a.d(s,{data:()=>e});const e={key:"v-494b840e",path:"/reference/plugin/dev/",title:"插件介绍",lang:"zh-CN",frontmatter:{},excerpt:"",headers:[{level:2,title:"开始",slug:"开始",children:[]},{level:2,title:"发布到 npm",slug:"发布到-npm",children:[]}],filePathRelative:"reference/plugin/dev/README.md",git:{updatedTime:165345025e4,contributors:[{name:"wanchun",email:"445436867@qq.com",commits:1}]}}},7415:(n,s,a)=>{a.r(s),a.d(s,{default:()=>t});const e=(0,a(6252).uE)('
一个插件是一个 npm
包,它能够为 Fes.js 创建的项目添加额外的功能,这些功能包括:
@fes/plugin-jest
添加了 fes test
命令,允许开发者运行单元测试。插件的入口是一个函数,函数会以 API 对象作为第一个参数:
export default (api)=>{\n api.describe({\n key: 'esbuild',\n config: {\n schema(joi) {\n return joi.object();\n },\n default: {}\n },\n enableBy: api.EnableBy.config,\n });\n}\n
API 对象是构建流程管理 Service 类的实例,api 提供一些有用的方法帮助你开发插件。
api.describe
用来描述插件:
key
,可以理解为插件的名称,在 .fes.js
中用 key
配置此插件。以 @fesjs/preset-
、@fesjs/plugin-
、@webank/fes-preset-
、@webank/fes-plugin-
、fes-preset-
和 fes-plugin-
开头的依赖会被 Fes.js 自动注册为插件或插件集。
所以编写好的插件想发布到 npm 供其他人使用,包名必须是 fes-preset-
和 fes-plugin-
开头。