前端内网开发npm 安装的几种方法

1、介绍

最近有同学问我,怎么在不联网的情况下安装依赖。一般我们开发都是有网的,那么配置一下register一下镜像路径就可以从国内的阿里云,淘宝,华为云,腾讯云等国内镜像文件。

有些同学开发项目会在内网开发,所以就需要离线去npm install一些依赖。

2、非联网/离线安装方法
---2.1搭建内网私服

我先通过一台电脑搭建一个内网服务,verdaccio是一个轻量级的私有npm代理注册服务

复制代码
//先安装一个代理服务
npm install -g verdaccio

//运行
verdaccio

//运行后的默认端口是4873,此时我们就可以设置镜像路径为这个代理地址
npm set registry http://localhost:4873/

//其他需求,如果你想要发布资源,推送到这个地址
npm publish --registry http://localhost:4873/

//项目成员安装依赖
npm install <package> --registry http://localhost:4873/

//也可以在项目中创建一个.npmrc文件
registry=http://localhost:4873/
---2.2npm pack 归档文件

重点讲一下这个方法

思路:首先我们用一台电脑,联网状态,去把所有依赖全部安装好,然后通过代码打成压缩包,拷贝到指定目录下

跟随潮流,同ts来吧,基础的创建项目啥的就不说了,讲重点

创建完项目后,如果需要用到ts,就执行这个命令tsc --init去创建一个tsconfig.json文件,在这个文件中将module:""设置为commonjs,即module:"commonjs",这里涉及到.js,.cjs,.mjs几种后缀的知识点,有机会再讲。。。

这里为什么要用commonjs,因为我们在编写代码的时候,是用的esm,esm不支持__dirname,__dirname只能在cjs中使用,后面我们编译出来就是cjs

我用去新建一个index.ts文件

复制代码
import { exeSync } from 'node:child-process'
import fs from 'node:fs'
import path from 'node:path'

//存放我们打包后的文件目录
const packageDir = path.join(__dirname, './packages')
//存在则不需要重复打包
if(!fs.existsSync(packageDir)){
    fs.mkdirSync(packageDir, {recursive: true})
}
//读取node_modules文件目录下的文件
const node_modules = path.join(__dirname, './node_modules')

function buildPackage() {
    const dirFileList = fs.readdirSync(node_modules ).filter(dit => {
        //排除.开头文件和@符号开头文件,其他请自行排除
        return !(dirFileList .startWith('.') || dirFileList .startWith('@'))
    })
    //遍历所查询到的文件
    dirFileList && dirFileList .map(dir => {
        //拿到文件的完整路径,后续打包路径
        const modules = path.join(node_modules, dir)
        //打包命令,需要引用,在第一行
        exeSync('npm pack', { cwd: modules })
        //将打包完的tgz文件找到
        const tgzfile = fs.readdirSync(modules).find(file => {
            return file.endsWith('.tgz')
        })
        if(tgzfile){
            //将找到的打包tgz文件移动到指定的package目录中
            fs.renameSync(path.join(modules,tgzfile), path.join(packageDir,tgzfile))
        }
        
    })
}
//执行
buildPackage()

//安装命令
npm install ./packages/xxxx.tgz
---2.3U盘拷贝

这个就不多说了

相关推荐
辻戋1 天前
从零实现React Scheduler调度器
前端·react.js·前端框架
徐同保1 天前
使用yarn@4.6.0装包,项目是react+vite搭建的,项目无法启动,报错:
前端·react.js·前端框架
Qrun1 天前
Windows11安装nvm管理node多版本
前端·vscode·react.js·ajax·npm·html5
中国lanwp1 天前
全局 npm config 与多环境配置
前端·npm·node.js
JELEE.1 天前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
TeleostNaCl1 天前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
前端大卫1 天前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友1 天前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理1 天前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻1 天前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js