HTML-05NPM使用踩坑

news2025/3/10 20:54:46

2025-03-04-NPM使用踩坑

本文讲述了一个苦逼程序员在使用NPM的时候突然来了一记nmp login天雷,然后一番折腾之后,终究还是没有解决npm的问题😞😞😞,最终使用cnpm完美解决的故事。

文章目录

  • 2025-03-04-NPM使用踩坑
    • @[toc]
    • 1-参考网址
    • 2-思路整理
    • 3-学习要点
    • 4-对比学习
      • 1-什么是npm、cnpm两者之间的区别
        • 1-npm 概述
        • 2-cnpm 概述
        • 3-npm 和 cnpm 的区别
      • 2-如何使用npm并配置国内镜像源
        • 一、安装 npm
          • 1. Windows 系统
          • 2. macOS 系统
          • 3. Linux 系统(以 Ubuntu 为例)
        • 二、更换 npm 镜像源为淘宝镜像
          • 1. 临时更换
          • 2. 永久更换
          • 3. 恢复默认镜像源
          • 4. 使用 nrm 管理镜像源
        • 三、常见问题与解决方案
          • 问题 1:输入 `npm login` 直接跳转到 Sign in to CNPM
          • 问题 2:使用 `https` 地址时报错 `request to https://registry.npmjs.org/-/v1/login failed, reason: connect ETIMEDOUT`
          • 问题 3:报错 `Unexpected token ‘.’`
          • 问题 4:安装包时速度慢或失败。
      • 3-如何使用cnpm并配置国内镜像源
        • 1-安装 cnpm
        • 2-全局安装 cnpm
        • 3-验证安装
        • 4-确保 cnpm 使用淘宝镜像
        • 5-查看当前镜像源
        • 6-手动设置为淘宝镜像源

1-参考网址

  • NpmLogin问题汇总:https://blog.csdn.net/HurryUpp/article/details/134928293

2-思路整理

  • 1)[X]遇到需要npmLogin的权限报错->网友推荐更换国内镜像
  • 2)[X]但是我跟着小跑一路都没有解决->果断放弃npm
  • 3)[√]最终解决方案->使用cnpm完美解决
  • 4)[√]如果cnpm遇到下载不了的包->使用pnpm完美解决

3-学习要点

  • 1)什么是npm、cnpm两者之间的区别?->NodeJs依赖管理

  • 2)如何使用npm并配置国内镜像源

  • 3)如何使用cnpm并配置国内镜像源

  • 4)核心操作

# 1)安装cnpm-已安装可跳过
- 下载安装cnpm
npm install -g cnpm --registry=https://registry.npmmirror.com
- 使用cnpm下载
cnpm install typescript


# 2)安装pnpm-已安装可跳过
- 下载安装pnpm
npm install -g pnpm --registry=https://registry.npmmirror.com
- 使用cnpm下载
pnpm install typescript


# 3)如果需要更新源
npm config set registry https://registry.npm.taobao.org/
npm config set registry https://registry.npmmirror.com/
npm config set registry https://registry.npmjs.org/

4-对比学习

1-什么是npm、cnpm两者之间的区别

1-npm 概述

npm 是 Node.js 的包管理器(Node Package Manager),它随着 Node.js 一起安装,是 JavaScript
生态系统中管理项目依赖和共享代码的重要工具。其核心功能与作用体现在以下多个方面:

  • 依赖管理npm 可以帮助开发者方便地安装、更新和删除项目所依赖的软件包。例如,在开发一个基于 React
    的前端项目时,你可以使用 npm install react react-dom 命令来安装 React 和 React DOM 这两个核心库。
  • 版本控制npm 支持语义化版本号(SemVer),可以精确指定项目依赖的软件包版本。在 package.json
    文件中,你可以看到类似 "react": "^18.2.0" 这样的版本声明,其中 ^ 表示兼容该主版本号下的最新版本。
  • 脚本执行npm 允许在 package.json 中定义脚本,通过 npm run
    命令来执行这些脚本。比如,你可以定义一个启动开发服务器的脚本 "start": "webpack-dev-server --open"
    ,然后使用 npm run start 来启动开发服务器。
  • 包发布:开发者可以将自己编写的软件包发布到 npm
    公共注册表(registry.npmjs.org),供其他开发者使用。发布后,其他开发者就可以通过 npm install 命令来安装使用你的包。

2-cnpm 概述

cnpm 是淘宝团队基于 npm 定制的一个镜像版本的包管理器,其目的主要是为了解决国内开发者在使用 npm 安装依赖包时网络速度慢、不稳定的问题。

  • 镜像源cnpm 使用了淘宝的镜像源(https://registry.npmmirror.com ),该镜像源会定期同步 npm
    官方注册表的内容,确保软件包的版本和内容与官方一致。
  • 安装使用:你可以通过 npm install -g cnpm --registry=https://registry.npmmirror.com 命令来全局安装 cnpm
    ,安装完成后就可以像使用 npm 一样使用 cnpm 来管理项目依赖。

3-npm 和 cnpm 的区别
  1. 镜像源
    • npm:默认使用的是官方的注册表(registry.npmjs.org),由于服务器位于国外,在国内访问时可能会受到网络限制,导致下载速度较慢,甚至出现连接超时的情况。
    • cnpm:使用的是淘宝的镜像源(https://registry.npmmirror.com ),该镜像源位于国内,下载速度通常比官方源快很多,尤其是对于一些体积较大的软件包,优势更为明显。
  2. 兼容性
    • npm:是 Node.js 官方推荐的包管理器,与 Node.js 生态系统的兼容性最好,能够保证安装的软件包与官方发布的版本完全一致。
    • cnpm:虽然大部分情况下与 npm 兼容,但由于是基于 npm
      定制的,可能会存在一些细微的差异。在某些特殊场景下,可能会出现安装的软件包与使用 npm 安装的版本不完全一致的情况,从而导致一些兼容性问题。
  3. 社区支持
    • npm:作为 Node.js 官方的包管理器,拥有庞大的社区支持,几乎所有的 Node.js 项目都会使用 npm
      来管理依赖。在遇到问题时,更容易在社区中找到相关的解决方案。
    • cnpm:主要是为国内开发者提供便利,社区支持相对较少。如果遇到与 cnpm
      相关的问题,可能在社区中找到的解决方案不如 npm 多。
  4. 命令使用
    • npm:命令使用广泛且标准,很多教程、文档和开源项目都是基于 npm 来编写命令示例的。
    • cnpm:命令与 npm 基本相同,但在一些企业级项目或者对依赖管理要求严格的场景中,可能会优先选择 npm
      ,而在个人开发或者对网络速度要求较高的场景中,cnpm 是一个不错的选择。

2-如何使用npm并配置国内镜像源

在前端开发中,npm(Node Package Manager)是 Node.js
的官方包管理工具,用于安装、共享和管理项目依赖。本文将详细介绍如何安装 npm、更换镜像源(以淘宝镜像为例),以及解决常见问题。

一、安装 npm

npm 通常会随 Node.js 一起安装,因此我们只需安装 Node.js 即可。

1. Windows 系统
  1. 下载安装包

    • 访问 Node.js 官方下载页面。
    • 选择适合你系统的 Windows 安装包(.msi 文件)。如果你使用的是 64 位系统,建议下载 64 位的安装包;如果是 32 位系统,则下载
      32 位的安装包。
  2. 运行安装程序

    • 双击下载的安装包,按照安装向导的提示进行操作。
    • 在安装过程中,你可以选择安装路径等选项,一般保持默认设置即可。
  3. 验证安装

    • 安装完成后,打开命令提示符(CMD)或 PowerShell,输入以下命令验证 Node.jsnpm 是否安装成功:
      node -v
      npm -v
      
    • 如果能正确显示 Node.jsnpm 的版本号,说明安装成功。
2. macOS 系统
  1. 使用安装包安装

    • 访问 Node.js 官方下载页面。
    • 选择适合 macOS 的安装包(.pkg 文件),下载后双击运行安装程序,按照提示完成安装。
  2. 使用 Homebrew 安装

    • 如果你已经安装了 Homebrew,可以使用以下命令安装 Node.js
      brew install node
      
  3. 验证安装

    • 安装完成后,打开终端,输入以下命令验证 Node.jsnpm 是否安装成功:
      node -v
      npm -v
      
3. Linux 系统(以 Ubuntu 为例)
  1. 添加 Node.js 源

    • 打开终端,运行以下命令添加 Node.js 官方源:
      curl -fsSL https://deb.nodesource.com/setup_18.x | sudo -E bash -
      
      • 这里的 18.x 是 Node.js 的版本号,你可以根据需要选择其他版本。
  2. 安装 Node.js 和 npm

    • 运行以下命令安装 Node.js 和 npm:
      sudo apt-get install -y nodejs
      
  3. 验证安装

    • 安装完成后,输入以下命令验证 Node.js 和 npm 是否安装成功:
      node -v
      npm -v
      
二、更换 npm 镜像源为淘宝镜像

由于网络原因,直接使用官方 npm
镜像源可能会导致安装速度较慢。我们可以将镜像源更换为淘宝镜像(现称为中国镜像,地址为 https://registry.npmmirror.com)。

1. 临时更换

如果你只需要临时使用淘宝镜像源来安装某个包,可以在安装命令中指定镜像源:

npm install <package-name> --registry=https://registry.npmmirror.com
  • <package-name> 替换为你要安装的包名。
2. 永久更换

如果你希望每次使用 npm 都默认使用淘宝镜像源,可以使用以下命令进行配置:

npm config set registry https://registry.npmmirror.com
  • 你可以通过以下命令验证镜像源是否已经成功更换:
    npm config get registry
    
    • 如果输出为 https://registry.npmmirror.com,则说明镜像源已经成功更换。
3. 恢复默认镜像源

如果你想恢复到 npm 的默认镜像源,可以使用以下命令:

npm config set registry https://registry.npmjs.org
4. 使用 nrm 管理镜像源

除了直接使用 npm config 命令来管理镜像源,你还可以使用 nrm(npm registry manager)工具来更方便地切换镜像源。

  1. 安装 nrm

    npm install -g nrm
    
  2. 查看可用镜像源

    nrm ls
    
    • 该命令会列出所有可用的镜像源,其中包括淘宝镜像(npmmirror)。
  3. 切换镜像源

    nrm use npmmirror
    
    • 该命令会将 npm 的镜像源切换为淘宝镜像。
  4. 测试镜像源速度

    nrm test npmmirror
    
    • 该命令会测试淘宝镜像源的响应速度,帮助你选择最快的镜像源。
三、常见问题与解决方案
问题 1:输入 npm login 直接跳转到 Sign in to CNPM
  • 原因:使用了淘宝的镜像地址(https://registry.npmmirror.com/https://r.cnpmjs.org/)。
  • 解决方法
    • 将镜像地址改回官方地址:
      npm config set registry http://registry.npmjs.org/
      
      • 注意使用 http 地址,而不是 https 地址。
问题 2:使用 https 地址时报错 request to https://registry.npmjs.org/-/v1/login failed, reason: connect ETIMEDOUT
  • 原因:官方镜像源的 https 地址可能在国内网络环境下无法正常访问。
  • 解决方法
    • 将镜像地址改为 http 地址:
      npm config set registry http://registry.npmjs.org/
      
问题 3:报错 Unexpected token ‘.’
  • 原因nvm(Node Version Manager)版本过低,导致 Node.js 版本也不兼容。
  • 解决方法
    1. 卸载所有 Node.js 版本:
      nvm uninstall --all
      
    2. 卸载 nvm
      • Node.js 安装目录中运行 unins000.exe
    3. 重新安装 nvmNode.js
问题 4:安装包时速度慢或失败。
    • 解决方法:更换为淘宝镜像源(https://registry.npmmirror.com),或者使用 nrm 测试并选择最快的镜像源。

3-如何使用cnpm并配置国内镜像源

1-安装 cnpm

cnpm 是淘宝团队基于 npm 定制的一个包管理工具,其镜像源默认指向淘宝镜像,方便国内开发者使用。以下是安装 cnpm 的步骤:

2-全局安装 cnpm

在命令行工具(如 Windows 的命令提示符、macOS 或 Linux 的终端)中执行以下命令来全局安装 cnpm

npm install -g cnpm --registry=https://registry.npmmirror.com

上述命令中,-g 表示全局安装,--registry=https://registry.npmmirror.com 是指定在安装 cnpm 时使用淘宝镜像源(现称中国镜像),以加快安装速度。

3-验证安装

安装完成后,可以通过查看 cnpm 版本号来验证是否安装成功,执行以下命令:

cnpm -v

如果能正确显示 cnpm 的版本信息,说明安装成功。


4-确保 cnpm 使用淘宝镜像

一般情况下,安装 cnpm 后它默认使用的就是淘宝镜像(https://registry.npmmirror.com)。但为了确保万无一失,你可以通过以下方式进行确认和更改:

5-查看当前镜像源

使用以下命令查看 cnpm 当前使用的镜像源:

cnpm config get registry

如果输出结果是 https://registry.npmmirror.com,则表示已经使用淘宝镜像源。

6-手动设置为淘宝镜像源

若查看的镜像源不是淘宝镜像源,可以使用以下命令将其设置为淘宝镜像源:

cnpm config set registry https://registry.npmmirror.com

设置完成后,再次使用 cnpm config get registry 命令进行验证,确保输出为 https://registry.npmmirror.com


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2311696.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

学校地摊尝试实验

学校地摊尝试实验 诸位&#xff0c;我要告诉诸位一件大消息&#xff0c;那就是&#xff0c;我将会利用学校时光的最后一段时间进行疯狂摆摊练习&#xff0c;如何进行摆摊&#xff0c;大家 听我娓娓道来。我要确定摆摊的目的&#xff0c; 第一&#xff0c;赚钱&#xff0c;第二…

MHA集群

一.MHA集群 MHA master high avavibility 主服务器高可用 如上图所示&#xff0c;我们之前说过&#xff0c;如果在主从复制架构中主服务器出现故障&#xff0c;就需要我们将从服务器作为主服务器&#xff0c;等故障的主服务器修复好之后&#xff0c;再将修好的主服务器作为从服…

Bazel搭建CUDA工程入门

环境版本&#xff1a; 工程目录&#xff1a; 测试输出&#xff1a; WORKSPACE 参考仓库&#xff1a;CUDA rules for Bazel 及 examples load("bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")http_archive(name "rules_cuda…

QILSTE灯珠:尺寸光电全解析

QILSTE灯珠&#xff1a;尺寸光电全解析 &#x1f31f; 型号H4-115BGRYA/5M&#xff0c;由QILSTE&#xff08;HongKong&#xff09;Technology Co., Ltd精心打造&#xff0c;以其1.6x1.5x0.4mm的紧凑外观尺寸&#xff0c;展现高亮红光、翠绿、蓝的缤纷色彩。 &#x1f4cf; 尺寸…

golang从入门到做牛马:第一篇-我与golang的缘分,go语言简介

还记得2018年的夏天,刚毕业的我不知道该做些什么,于是自学了一周的go语言,想要找一份go语言工作的代码,当时的go还没有go mod来管理依赖包,在北京找了一个月的工作,找到了一个小公司做了后端开发,当然使用go语言开发,带着兴奋劲,年轻身体也好,边努力学习,边工作。 时…

用IdleHandler来性能优化及原理源码分析

背景&#xff1a; 经常在做一些app冷启动速度优化等性能优化工作时候&#xff0c;经常可能会发现有时候需要引入一些第三方sdk&#xff0c;或者库&#xff0c;这些库一般会要求我们在onCreate中进行初始化等&#xff0c;但是onCreate属于生命周期的回调方法&#xff0c;如果on…

如何在WPS中接入DeepSeek并使用OfficeAI助手(超细!成功版本)

目录 第一步&#xff1a;下载并安装OfficeAI助手 第二步&#xff1a;申请API Key 第三步:两种方式导入WPS 第一种:本地大模型Ollama 第二种APIKey接入 第四步&#xff1a;探索OfficeAI的创作功能 工作进展汇报 PPT大纲设计 第五步&#xff1a;我的使用体验(体验建议) …

Swagger-01.介绍和使用方式

一.Swagger介绍 有了接口文档&#xff0c;我们就可以根据接口文档来开发后端的代码了。如果我们开发完了某个功能&#xff0c;后端如何验证我们开发的是否正确呢&#xff1f;我们就需要测试&#xff0c;使用Swagger就可以帮助后端生成接口文档&#xff0c;并且可以进行后端的接…

Unity 使用NGUI制作无限滑动列表

原理&#xff1a; 复用几个子物体&#xff0c;通过子物体的循环移动实现&#xff0c;如下图 在第一个子物体滑动到超出一定数值时&#xff0c;使其放到最下方 --------------------------------------------------------------》 然后不停的循环往复&#xff0c;向下滑动也是这…

【并发编程】聊聊定时任务ScheduledThreadPool的实现原理和源码解析

ScheduledThreadPoolExecutor 是在线程池的基础上 拓展的定时功能的线程池&#xff0c;主要有四种方式&#xff0c;具体可以看代码&#xff0c; 这里主要描述下 scheduleAtFixedRate &#xff1a; 除了第一次执行的时间&#xff0c;后面任务执行的时间 为 time MAX(任务执行时…

Java-servlet(三)Java-servlet-Web环境搭建(下)详细讲解利用maven和tomcat搭建Java-servlet环境

Java-servlet&#xff08;三&#xff09;Java-servlet-Web环境搭建&#xff08;下&#xff09;利用maven和tomcat搭建Java-servlet环境 前言一、配置maven阿里镜像二、利用IDEA创建maven文件创建maven文件删除src文件创建新的src模版删除example以及org文件 三、在第二个xml文件…

如何选择DevOps平台?GitHub、GitLab、BitBucket、Jenkins对比与常见问题解答

本文内容来源github.com&#xff0c;由GitHub中国授权合作伙伴-创实信息进行翻译整理。 欢迎通过021-61210910、customershcsinfo.com联系我们&#xff0c;免费试用GitHub企业版。 软件是当今领先企业的核心&#xff0c;而开发者则是软件的核心。GitHub作为一个完整的开发者平台…

react中的fiber和初次渲染

源码中定义了不同类型节点的枚举值 组件类型 文本节点HTML标签节点函数组件类组件等等 src/react/packages/react-reconciler/src/ReactWorkTags.js export const FunctionComponent 0; export const ClassComponent 1; export const IndeterminateComponent 2; // Befo…

闭包+求解候选码+最小函数依赖集

一、闭包 直接上例题 简单明了 A的闭包ABC ABC的闭包ABCD ABCD的闭包ABCDE ABCDE的闭包ABCDEG 等于集合R的全集 所以A的闭包为ABCDEG AB的闭包为ABC 二、候选码 答案&#xff1a; 三、最小函数依赖集 求F的最小函数依赖集 去掉多余的 然后&#xff01; 化为最简

DeepSeek 助力 Vue3 开发:打造丝滑的表格(Table)之功能优化,添加表格空状态提示,带插图的空状态,Table7空状态2

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 Deep…

Unity Shader 学习15:可交互式雪地流程

本质是 利用顶点变换实现的&#xff1a; 通过一个俯视整个场地的正交摄像机&#xff0c;根据绑定在移动物体身上的粒子系统&#xff0c;来获取物体移动过的位置&#xff0c;记录到一张RenderTexture上作为轨迹图&#xff0c;再通过这张图来对雪地做顶点变换。 1. 由于顶点变换需…

嵌入式开发之串行数据处理

前题 前面几篇文章写了关于嵌入式软件开发时&#xff0c;关于串行数据处理的一些相关内容&#xff0c;有兴趣的可以看看《嵌入式开发&#xff1a;软件架构、驱动开发与串行数据处理》、《嵌入式软件开发之生产关系模型》和《嵌入式开发之Modbus-RTU协议解析》相关的内容。从业十…

Centos的ElasticSearch安装教程

由于我们是用于校园学习&#xff0c;所以最好是关闭防火墙 systemctl stop firewalld systemctl disable firewalld 个人喜欢安装在opt临时目录&#xff0c;大家可以随意 在opt目录下创建一个es-standonely-docker目录 mkdir es-standonely-docker 进入目录编辑yml文件 se…

SyntaxError: Unexpected token ‘xxx‘

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》、《前端求职突破计划》 &#x1f35a; 蓝桥云课签约作者、…

Unity自定义区域UI滑动事件

自定义区域UI滑动事件 介绍制作1.创建一个Image2.创建脚本 总结 介绍 一提到滑动事件联想到有太多的插件了比如EastTouchBundle&#xff0c;今天想单纯通过UI去做一个滑动事件而不是基于Box2d或者Box去做滑动事件。 制作 1.创建一个Image 2.创建脚本 using UnityEngine; us…