组件化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文件中引用

相关推荐
Erishen3 分钟前
🚀 重新定义前端组件安装体验:shadcn + Bun 的极致开发效率
前端
冬奇Lab3 分钟前
Vercel部署全攻略:从GitHub到上线,10分钟让你的前端项目免费拥有自己的域名
前端·后端·node.js
牛马1116 分钟前
Flutter Web性能优化标签解析
前端·flutter·性能优化
Bigger6 分钟前
Tauri (25)——消除搜索列表默认选中的 UI 闪动
前端·react.js·weui
李少兄18 分钟前
简单讲讲 SVG:前端开发中的矢量图形
前端·svg
前端小万19 分钟前
告别 CJS 库加载兼容坑
前端·前端工程化
天远数科19 分钟前
Node.js全栈开发:深度集成天远贷前风险报告接口打造风控中台
大数据·node.js
恋猫de小郭19 分钟前
Flutter 3.38.1 之后,因为某些框架低级错误导致提交 Store 被拒
android·前端·flutter
JarvanMo23 分钟前
Flutter 需要 Hooks 吗?
前端
光影少年33 分钟前
前端如何虚拟列表优化?
前端·react native·react.js