当前位置: 首页 > news >正文

从零到一:编写一个简单的 Umi 插件并发布到 npm

一、前言

        最近在学习 Umi 框架时,发现它的插件机制特别灵活。于是我尝试写一个最简单的 Umi 插件,比如在启动项目时输出一句提示语。

        做完这个我们可以了解插件的基本规范,以及如何打包发布到npm,如何让别人npm install 直接安装使用。

二、创建插件项目

        创建项目文件夹    

        这样项目就创建好了,而且携带了package.json文件,现在我们需要添加一个依赖umi,然后安装umi。

执行pnpm install 就自动安装好依赖了。

三、注册登录npm然后发布本地插件到npm

        注册到npm官网就可以,这里我直接登录好了。

        

        登录之后就可以直接npm publish 直接上传到npm了。

        也可以用命令注册,npm adduser 然后输入账户密码就可以了,邮箱也需要填写。

4、发布之后通过npm install 安装插件并且使用

        首先可以本地写好插件上传发布之前在自己项目用pnpm link 插件名称本地测试一下。

        首先在插件项目目录pnpm link 将插件包link到npm 或者pnpm环境

        然后在项目目录npm link 插件包名运行即可

        在自己的项目输入npm install 自己的插件名称。

        这样插件就安装完成了。

        安装完之后我们在自己的umi项目里面,在.umirc.ts配置或者config/config.ts中配置defineConfig中的plugins插件配置项就可以了。

import { defineConfig } from "umi";export default defineConfig({routes: [{ path: "/", component: "index" },{ path: "/docs", component: "docs" },{ path: "/login", component: "login", layout: false },{ path: "/weather", component: "weather" },{ path: "/promise", component: "Promise" },{ path: "/aiChat", component: "aiChat", layout: false },{ path: "/websocket", component: "websocket", layout: false },{ path: "/test", component: "test", layout: false },{ path: "/streamingChat", component: "streamingChat", layout: false },{ path: "/fileUploadDemo", component: "FileUploadDemo", layout: false },],npmClient: "pnpm",mock: {include: ["src/mock/**/*.ts"], // 启用mock功能并指定mock文件位置},plugins: ["umi-plugin-hello-lcy"],
});

        运行项目控制台会输出

        

5、常见问题       

问题原因解决办法
npm error EPRIVATEpackage.json"private": true删除该字段
npm error 402 Payment Required使用了作用域包(@xxx/)且没设置公开加上 --access public
插件未生效没在 Umi 配置文件中启用确认在 plugins 数组中声明

6、总结

这一套流程下来,你已经理解了 Umi 插件的基本结构,能在本地测试插件(npm link 插件名称),成功将插件发布到 npm,
并能被其他项目直接安装使用。

值得一提的工具
1.nrm包镜像源管理工具类似于nvm,管理镜像源
2. 如果要在npm公布上传插件包,需要切换到对应npm镜像源然后登录
3. 如果公司内网也需要切换到内网镜像源
4. 相关命令为 nrm ls 查看当前镜像源以及使用的镜像源
5. nrm use 切换镜像源

http://www.dtcms.com/a/601562.html

相关文章:

  • 企业做网站的费用如何科目邢台哪个公司做网站好
  • R语言编译器使用技巧与常见问题
  • 国内哪家网站做的系统纯净南京网站开发荐南京乐识
  • 网站建设单选题wordpress新手教程
  • 白牌笔记本电脑制造商能提供哪些定制服务?
  • ubuntu 22.04 升级openssh默认版本8.9p1 到10.1p1
  • User Prompt 与 System Prompt:大模型沟通的“双引擎”机制深度拆解
  • 在Anaconda Prompt完成模型训练
  • AR党建互动台-VR智慧党建沙盘-AR党建识别桌
  • 济宁做网站的大连建设
  • 建设银行新版网站上线免费网站如何赚钱
  • [Linux]学习笔记系列 -- [kernel]kthread
  • 网站开发备案帮企业做网站
  • 链盾shieldchain | 数据库、用户注册、登录、标识查询、商业软件申请和处理、消息
  • C++ set 容器:有序唯一元素集合的深度解析与实战
  • 前端的dist包放到后端springboot项目下一起打包
  • Swift 6.2 列传(第六篇):内存安全的 “峨眉戒令”
  • 毕设用别人网站做原型企业英语培训哪里好
  • 网站排名优化系统百度竞价什么意思
  • 网站群项目建设实施进度计划衡水网站建设电话
  • 【自然语言处理】基于混合基的句子边界检测算法
  • 快快测(KKCE)TCping 检测全面升级:IPv6 深度覆盖 + 多维度可视化,重构网络性能监测新体验
  • 句容网站移动互联网软件开发
  • vs编译c语言 | 详细解析如何配置与调试Visual Studio环境
  • 浙江火电建设有限公司网站营销策划公司名字简单大气
  • 自动驾驶与联网车辆网络安全:系统级威胁分析与韧性框架
  • 野火fpga笔记
  • 在 Ubuntu 上安装 MySQL 的详细指南
  • 智慧医疗:FHIR R5、联邦学习与MLOps三位一体的AI产品化实战指南(上)
  • Unity Shader Graph 3D 实例 - 基础的模型颜色渲染