解决 npm install canvas@2.11.2 失败的问题

文章目录

  • 前言
  • [Mac 版](#Mac 版)
    • 安装系统依赖(macOS)
    • [确保 Xcode 命令行工具已安装](#确保 Xcode 命令行工具已安装)
    • [将 npm 镜像源更改为淘宝镜像源](#将 npm 镜像源更改为淘宝镜像源)
    • [全局安装 node-gyp](#全局安装 node-gyp)
    • [清除 npm 缓存并开始安装](#清除 npm 缓存并开始安装)
    • 安装成功
  • [Windows 版](#Windows 版)
    • [安装 vscode](#安装 vscode)
    • [将 npm 镜像源更改为淘宝镜像源](#将 npm 镜像源更改为淘宝镜像源)
    • [全局安装 node-gyp](#全局安装 node-gyp)
    • [清除 npm 缓存并开始安装](#清除 npm 缓存并开始安装)
    • 安装成功

前言

项目中使用了 canvas npm包来实现 node 服务端数据成图的功能。但是在项目中使用 npm install 安装失败,经过各种和 AI 沟通的尝试后,终于指定版本的 canvas 安装成功,项目也运行成功,在此记录一下安装方法。


Mac 版

  • 操作系统:MacOS Sequoia 15.5
  • node版本:v15.14.0
  • npm版本:v7.7.6

安装系统依赖(macOS)

canvas 需要系统级图形库支持,使用Homebrew安装:

bash 复制代码
brew install pkg-config cairo pango libpng jpeg giflib librsvg

确保 Xcode 命令行工具已安装

bash 复制代码
xcode-select --install

将 npm 镜像源更改为淘宝镜像源

bash 复制代码
# 查看当前配置
npm config get registry
# 设置为淘宝镜像
npm config set registry https://registry.npmmirror.com/
# 恢复为官方镜像
npm config set registry https://registry.npmjs.org/

全局安装 node-gyp

node-gyp是一个Node.js的原生插件构建工具,用于编译C++扩展模块。很多Node.js模块,比如canvas,都包含C++代码,需要编译后才能在特定平台上运行。

bash 复制代码
npm install -g node-gyp

清除 npm 缓存并开始安装

bash 复制代码
# 清除npm缓存
npm cache clean --force
npm cache verify
# 删除指定文件
rm -rf node_modules package-lock.json
npm install

安装成功

执行 npm install 后,需要等待10分钟左右才会安装成功,进程会卡在 core-js@2.6.12 处,如下图:

等待中截图

安装成功截图


Windows 版

  • 操作系统:Windows 11
  • node版本:v15.14.0
  • npm版本:v7.7.6

安装 vscode

官网下载地址

将 npm 镜像源更改为淘宝镜像源

bash 复制代码
# 查看当前配置
npm config get registry
# 设置为淘宝镜像
npm config set registry https://registry.npmmirror.com/
# 恢复为官方镜像
npm config set registry https://registry.npmjs.org/

全局安装 node-gyp

node-gyp是一个Node.js的原生插件构建工具,用于编译C++扩展模块。很多Node.js模块,比如canvas,都包含C++代码,需要编译后才能在特定平台上运行。

bash 复制代码
npm install -g node-gyp

清除 npm 缓存并开始安装

bash 复制代码
# 清除npm缓存
npm cache clean --force
npm cache verify
# 删除指定文件
rmdir /s /q node_modules && del /f /q package-lock.json
npm install

安装成功

执行 npm install 后,很快就安装成功了,不会像 Mac 端卡着。如下图:

相关推荐
全栈前端老曹1 天前
【包管理】npm init 项目名后底层发生了什么的完整逻辑
前端·javascript·npm·node.js·json·包管理·底层原理
全栈前端老曹2 天前
【包管理】read-pkg-up 快速上手教程 - 读取最近的 package.json 文件
前端·javascript·npm·node.js·json·nrm·package.json
2301_818732063 天前
安装了node,但是cmd找不到node和npm,idea项目也运行失败 已解决
前端·npm·node.js
Sapphire~4 天前
odoo-087 安装 npm (node ok npm not)
linux·运维·npm
Benny的老巢4 天前
【n8n工作流入门02】macOS安装n8n保姆级教程:Homebrew与npm两种方式详解
macos·npm·node.js·n8n·n8n工作流·homwbrew·n8n安装
2301_818732064 天前
下载nvm后,通过nvm无法下载node,有文件夹但是为空 全局cmd,查不到node和npm 已解决
前端·npm·node.js
稀饭524 天前
用changeset来管理你的npm包版本
前端·npm
就知道你是成心的4 天前
npm pack 一键构建npm离线包
npm
GuMoYu5 天前
npm link 测试本地依赖完整指南
前端·npm
爱写程序的小高5 天前
npm ERR! code ERESOLVE npm ERR! ERESOLVE unable to resolve dependency tree
前端·npm·node.js