组件化npm包打包和使用

背景:本地环境对功能组件提取,开发环境下通过本地路径引用,发布模式下走npm包引用

1、项目下新建packages/HelloWorld文件夹,在此文件夹下运行终端

npm init

新建packages/HelloWorld/index.vue文件

新建packages/HelloWorld/index.js文件

javascript 复制代码
import helloworld from "./index.vue";

export {
  helloworld
}

1、本地打包:

npm pack

将helloworld-1.0.1.tgz 放到项目根目录下,运行终端命令

npm install helloworld-1.0.1.tgz //加载组件

npm uninstall helloworld-1.0.1.tgz //删除组件

在项目.vue文件中引用

html 复制代码
<script setup>
import {helloworld} from "helloworld"
</script>

<template>
  <div>
    <span>测试helloworld组件</span>
    <helloworld></helloworld>
  </div>
</template>

2、私库打包

npm config get registry //查看 npm 配置私库地址

npm config set registry ${私库地址:https://registry.npmjs.org/} //设置私库地址

npm adduser --registry ${私库地址:https://registry.npmjs.org/} //添加用户

npm login //登录私库账号

npm publish //将npm包推送到私库

npm unpublish ${包名} --force //删除已发布的包

npm install ${包名} //下载对应包

3、本地路径访问

安装@types/node,配置@=src目录路径

npm install @types/node --save-dev

在vite.config.ts文件添加配置

"hello-world": resolve(__dirname, "packages/HelloWorld")

在项目.vue文件中引用

相关推荐
看到请催我学习18 分钟前
如何实现两个标签页之间的通信
javascript·css·typescript·node.js·html5
twins352037 分钟前
解决Vue应用中遇到路由刷新后出现 404 错误
前端·javascript·vue.js
qiyi.sky1 小时前
JavaWeb——Vue组件库Element(3/6):常见组件:Dialog对话框、Form表单(介绍、使用、实际效果)
前端·javascript·vue.js
煸橙干儿~~1 小时前
分析JS Crash(进程崩溃)
java·前端·javascript
安冬的码畜日常1 小时前
【D3.js in Action 3 精译_027】3.4 让 D3 数据适应屏幕(下)—— D3 分段比例尺的用法
前端·javascript·信息可视化·数据可视化·d3.js·d3比例尺·分段比例尺
l1x1n02 小时前
No.3 笔记 | Web安全基础:Web1.0 - 3.0 发展史
前端·http·html
昨天;明天。今天。2 小时前
案例-任务清单
前端·javascript·css
zqx_73 小时前
随记 前端框架React的初步认识
前端·react.js·前端框架
惜.己3 小时前
javaScript基础(8个案例+代码+效果图)
开发语言·前端·javascript·vscode·css3·html5
什么鬼昵称4 小时前
Pikachu-csrf-CSRF(get)
前端·csrf