npm上传自己封装的插件(vue+vite)

一、npm账号及发包删包等命令

若没有账号,可在npm官网:https://www.npmjs.com/login 进行注册。

在当前项目根目录下打开终端命令窗口,常见命令如下:

1、登录命令:npm login (不用每次都重新登录,失效了再登)

2、首次登录:npm adduser

注:根据提示依次输入:用户名、密码(输入内容不展示)、邮箱、邮箱验证码。

3、发包命令:npm publish

注:同一个包不能重复发布同一个版本,每次发布需要修改版本号。

4、删包命令:npm unpublish 包名 --force (例:npm unpublish plugins --force)

注:只能删除72小时以内发布的包,且删除的包24小时内不允许重复发布,执行失败可能是网络不好,重新执行下又可以了。

5、删除指定版本:npm unpublish 包名@版本号 --force (例:npm unpublish plugins@1.0.0 --force)

注:会自动回退到上个版本,删除后不可再上传相同的该版本号。

执行npm publish可能遇到的报错:

1、403 Forbidden - PUT https://registry.npmjs.org/plugins - You do not have permission to publish "plugins". Are you logged in as the correct user?

解:因为plugins包名已经存在,不是作者没有权限修改已经存在的包,需要换个包名。

2、400 Bad Request - PUT https://registry.npmjs.org/myPlugins - "defPlugins" is invalid for new packages.

解:包名不支持驼峰命名,把myPlugins换成my-plugins就行了。

二、vue项目打包及插件发布相关配置

1、单个插件发布

例如在/src/packages/test123/index.vue中开发需要上传的插件

vite.config.js文件打包配置

javascript 复制代码
import { defineConfig } from 'vite';
import { resolve } from 'path';
export default defineConfig({
  build: {
    outDir: 'dist',
    lib: {
      entry: resolve(__dirname, "./src/packages/test123/index.vue"), // 文件路径
      name: 'test123',
      fileName: 'test123.min' // 打包后生成的文件名
    },
    rollupOptions: {
      external: ['vue'],
      output: {
        globals: {
          vue: 'Vue'
        }
      }
    }
  }
})

注:打包后dist文件夹会自动生成test123.min.js、style.css这两个下方需要用到的文件。

package.json文件配置

javascript 复制代码
{
  "name": "test123", // 发布插件的名称
  "private": false, // 是否私有,设置为false
  "version": "1.0.0", // 发布的版本号
  "type": "module",
  "main": "dist/test123.min.js", // 插件入口文件
  "style": "dist/style.css",
  "files": [
    "dist"
  ],
  "scripts": {...},
  "dependencies": {...},
  "devDependencies": {...}
}

注意:npm发布包或版本根据package.json中配置信息来决定,vite.config.js文件中的build配置只是为了打包生成dist。所以如果只是修改包名或者版本号不需要重新打包,直接修改json文件对应的信息即可。

项目应用:

安装依赖:npm i test123 --save

页面使用:

javascript 复制代码
<script>
	import test from 'test123'; 
	import 'test/style.css'; // 可根据下面注意省略此行
</script>
<template>
	<test></test>
</template>

注意:可以在插件发布之前在dist/test123.min.js文件中加import './style.css';这行引入代码,这样就不用在每次使用的时候都单独引入插件css文件了。

2、多个插件批量发布

例如在/src/packages文件下创建多个.vue文件,并在/src/packages/index.js文件中批量注册:

javascript 复制代码
import test123 from './test123/index.vue';
import test456 from './test456/index.vue';
const myCompList = [test123, test456];
// 批量注册组件
const install = function (Vue) {
    myCompList.forEach(comp => {
        Vue.component(comp.name, comp);
    })
}
export default install;

vite.config.js文件打包配置

javascript 复制代码
import { defineConfig } from 'vite';
import { resolve } from 'path';
export default defineConfig({
  build: {
    outDir: 'dist',
    lib: {
      entry: resolve(__dirname, "./src/packages/index.js"),
      name: 'my-plugins',
      fileName: format => `my-plugins-${format}.js`
    },
    rollupOptions: {
      external: ['vue'],
      output: {
        globals: {
          vue: 'Vue'
        }
      }
    }
  }
})

package.json文件配置

javascript 复制代码
{
  "name": "my-plugins",
  "private": false,
  "version": "0.0.1",
  "type": "module",
  "main": "dist/my-plugins-es.js",
  "style": "dist/style.css",
  "files": ["dist"],
  "scripts": {...},
  "dependencies": {...},
  "devDependencies": {...}
}

项目应用:

安装依赖:npm i my-plugins --save

main.js文件

javascript 复制代码
import { createApp } from 'vue'
import App from './App.vue'
import myPlugins from 'my-plugins';
import 'my-plugins/dist/style.css';
createApp(App).use(myPlugins);

页面使用:(不需要再单独引入插件test123、test456)

javascript 复制代码
<template>
	<test123></test123>
	<test456></test456>
</template>

三、关于README.md文档编写

README.md是一个使用Markdown格式编写的文本文件,通常用于描述软件项目、库或文档的基本信息。‌

下图借用百度搜索结果:

相关推荐
本末倒置183几秒前
Bun 内置模块全解析:告别第三方依赖,提升开发效率
前端·javascript·node.js
踩着两条虫1 分钟前
AI 驱动的 Vue3 应用开发平台 深入探究(二):核心概念之DSL模式与数据模型
前端·vue.js·ai编程
牛奶14 分钟前
200 OK不是"成功"?HTTP状态码潜规则
前端·http·浏览器
Hilaku1 小时前
OpenClaw 很爆火,但没人敢聊它的权限安全🤷‍♂️
前端·javascript·程序员
ConardLi1 小时前
OpenClaw 完全指南:这可能是全网最新最全的系统化教程了!
前端·人工智能·后端
丁哥2 小时前
99.9%纯AI 做了一个ICO图标生成器(免费 全尺寸 不限文件大小)2ICO.CN欢迎品鉴
前端
兆子龙2 小时前
React Native 完全入门:从原理到实战
前端·javascript
哇哇哇哇2 小时前
vue3 watch解析
前端
SuperEugene2 小时前
Vite 实战教程:alias/env/proxy 配置 + 打包优化避坑|Vue 工程化必备
前端·javascript·vue.js
leafyyuki2 小时前
用 AI 和 SDD 重构 Vue2 到 Vue3 的实践记录
前端·人工智能