vite+vue3发布自己的npm组件+工具函数

记录一下个人最近一次发布npm组件的过程:

一、创建组件和工具函数

  1. 执行命令创建一个空项目: npm create vite 创建过程稍微有些慢,不知何故?其中选择vue , 个人暂时使用的JS 。
  2. 在 src 目录下面创建一个文件 package 存放组件和公共的JS方法

案例中 table 是放组件的, utils 是放方法的。

table组件 里面的主要内容就是个人业务组件,随便写点

复制代码
<template>
  <input type="text" v-model="MyValue">
  <div>
    结果:{{ MyValue }}
  </div>
  <button @click="handelEvent"> 测试按钮 </button>
</template>

<script setup>
import { ref } from "vue";
const MyValue = ref("");
const emit = defineEmits(["testBtn"]);
const handelEvent = () => {
  emit("testBtn", MyValue.value);
};
</script>

<script>
export default {
  name: "eosBtn",
};
</script>

这里遇到一个疑问,组件名称的暴露:必须通过下面的方式。

复制代码
export default {
  name: "eosBtn",
}; 

我最开始用的组合式api 直接暴露的,竟然无法使用,如有知道原因的,还请赐教一下。

复制代码
<script setup name="eosBtn"> </script>

函数方法,utils文件 也随便写一个:

复制代码
// indes.js
import { handleFirstUpperCase } from "./utils.js";
export default { handleFirstUpperCase };


// utils.js
/* 
* 首字母转大写
*/
export function handleFirstUpperCase(str) {
    return str.replace(/( |^)[a-z]/g, (L) => L.toUpperCase());
}
  1. 开始暴露出去组件和方法,在package 下的index.js 写

    import eosBtn from './table/index.vue'
    import EUtils from './utils/index.js'

    const components = [eosBtn]
    const install = function (Vue) {
    components.map(el => {
    Vue.component(el.name, el) // 注册组件
    })
    }
    export default { install, EUtils }

  2. 本地自测,还是在当前的项目下,在main.js 里面引入和注册组件以及方法

    import { createApp } from 'vue'
    import './style.css'
    import App from './App.vue'
    import testUi from './package/index.js'
    const app = createApp(App)

    app.config.globalProperties.EUtils = testUi.EUtils; //公共方法
    console.log(testUi);
    app.use(testUi.install)
    app.mount('#app')

  3. 在app.vue 中使用组件进行测试

    <template> <eosBtn @testBtn="testBtn" /> </template> <script setup> import { getCurrentInstance, ref, defineComponent } from "vue"; const { proxy } = getCurrentInstance(); const testBtn = (val) => { console.log(proxy.EUtils.handleFirstUpperCase(val)); }; </script>

二、发布组件

  1. 设置包的名称,版本,导出路径等相关信息, 在package.json

    {
    "name": "eos-tms-base",
    "private": false,
    "version": "0.0.5",
    "type": "module",
    "files": [
    "dist/*",
    "eos-tms-base.d.js"
    ],
    "main": "dist/eos-tms-base.umd.js",
    "module": "dist/eos-tms-base.es.js",
    "scripts": {
    "dev": "vite",
    "build": "vite build",
    "preview": "vite preview"
    },
    "dependencies": {
    "vue": "^3.3.11"
    },
    "devDependencies": {
    "@vitejs/plugin-vue": "^4.5.2",
    "vite": "^5.0.8"
    }
    }

  2. 设置vite.config.js

    import { defineConfig } from 'vite'
    import vue from '@vitejs/plugin-vue'

    // https://vitejs.dev/config/ https://juejin.cn/post/7257144279050403896
    export default defineConfig({
    plugins: [vue()],
    build: {
    rollupOptions: {
    // 请确保外部化那些你的库中不需要的依赖
    external: ['vue'],
    output: {
    // 在 UMD 构建模式下为这些外部化的依赖提供一个全局变量
    globals: {
    vue: 'Vue',
    },
    },
    },
    lib: {
    entry: 'src/package/index.js',
    name: 'eos-tms-base',
    fileName: (format) => eos-tms-base.${format}.js,
    },
    },
    })

  3. 执行打包命令,打包发布:npm run build 打包后的文件

  4. 接着就是登录npm, 执行命令 npm login , 没有账户的自行注册,上传失败的,检查npm 代理路径是否为官方的,如果是淘宝镜像需要自行切换到官方才可使用,包名是否已经在插件市场存在。

设置 npm 的 registry 为官方源 npm config set registry https://registry.npmjs.org

  1. 到npm 官网查看是否发布成功。

最后就是创建一个空项目,自己下载插件,进行引入,自测。
npm i eos-tms-base

相关推荐
崔庆才丨静觅5 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby60616 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了6 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅6 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅6 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅7 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment7 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅7 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊7 小时前
jwt介绍
前端
爱敲代码的小鱼7 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax