npm i 你会用几种方式引入?

1. 背景

在使用npm install 安装包时,我们都是使用在npm官方发布的包进行引入。你知道还会有其他几种方式进行引入吗?

本文主要介绍下其他几种方式引入:

  1. 本地文件夹引入
  2. 本地压缩包引入
  3. 远程仓库引入

官方文档:

2. 案例

2.1 项目创建

使用npm create vite创建项目,以引入element-plus为例子。

下载element-plus源码,修改button源码后进行打包,引入dist中的element-plus文件夹。

打包后的进行引入创建后项目,如下:

js 复制代码
项目
├─ deps
|  ├─element-plus
|  ├─element-plus.tar.gz
|─ src
|  ├─app.vue
|  └main.js

main.js

js 复制代码
import { createApp } from 'vue'
import App from './App.vue'

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'

const app = createApp(App)
app.use(ElementPlus).mount('#app')

app.vue

vue 复制代码
<template>
	<el-button type="primary">你好</el-button>
</template>

2.2 本地文件夹/压缩包引入

    1. 使用文件夹 npm i element-plus ./deps/element-plus
    1. 使用压缩包,使用tar zcvf element-plus.tar.gz -C ./element-plus .生成压缩包, -C 不会有element-plus目录,安装npm i element-plus ./deps/element-plus.tar.gz

优势:

  • 节省磁盘空间
  • 避免修改源代码

两种方式,npm run dev 运行后

2.3 远程地址

可以将打包后放在私服或者github上,此处以github举例:

  1. 创建一个git仓库,将打包后文件推送到远程,分别将未修改源码的打tag为v2.3.0,修改源码的打tag为v2.3.1。
  1. 使用
  • 未修改源码 tag为v2.3.0 ,安装 npm i element-plus git@github.com:f5l5y5/my-element.git#v2.3.0
  • 修改源码 tag为v2.3.1,安装 npm i element-plus git@github.com:f5l5y5/my-element.git#v2.3.1

注意: node版本不同,安装和显示会有所差别,参考官方文章为准

3. 总结

本地测试包时,不需要发到npm,可以方便测试开发。

简单总结下:

  1. 本地文件夹引入:可以将需要引入的包放置在本地文件夹中,然后使用相对路径或绝对路径进行引入,例如npm i ./path/to/package

  2. 本地压缩包引入:可以将需要引入的包打包成压缩包(通常是.tar.gz格式),然后使用相对路径或绝对路径进行引入,例如npm i ./path/to/package.tar.gz

  3. 远程仓库引入:可以将需要引入的包发布到远程仓库(如GitHub),然后使用远程仓库的地址加上指定的版本或标签来进行引入,例如npm i git@github.com:user/repo.git#v1.0.0

注意,不同的包管理工具(如npm、yarn、pnpm)可能对这些引入方式的支持和语法略有差异,请参考对应工具的官方文档进行操作。

如有错误,请指正!O^O!!!

相关推荐
ZC1995925 分钟前
Node.js npm 安装过程中 EBUSY 错误的分析与解决方案
前端·npm·node.js
升鲜宝供应链及收银系统源代码服务7 分钟前
生鲜配送供应链管理系统源代码之升鲜宝社区团购商城小程序(一)
java·前端·数据库·小程序·notepad++·供应链系统源代码·多门店收银系统
ghhgy53111 分钟前
Chrome、Edge浏览器显示“由贵组织管理”,删除、解决方法
前端·chrome·edge
533_12 分钟前
[svg] fill-opacity、stroke-opacity与opacity
前端
九天轩辕13 分钟前
Chromium 内核深度剖析:HTML 属性解析限制导致的视频静音失效问题
前端·html·音视频
cmdyu_14 分钟前
Chrome 132+ 篡改猴脚本不生效的排查与解决
前端·chrome
曹牧14 分钟前
Java:解析Json字符串格式要求
java·linux·运维·前端
wuhen_n21 分钟前
终局之战:全链路性能体检与监控
前端·javascript·vue.js
Greg_Zhong23 分钟前
认识前端自动化测试、小程序中如何实现单元测试
前端·小程序·单元测试
Dovis(誓平步青云)24 分钟前
《 One-KVM 的硬件级远控方案,通过 玩客云 等廉价硬件实现 视频信号采集 + 键鼠模拟 + 虚拟 USB》
运维·前端·网络·ai编程