记一次跑前端老项目的问题
一、前言
在一次跑前端老项目的时候,遇到了一些坑,这里记录一下。
二、过程
1、下载依赖
使用
powershell
npm install
下载很久,然后给我报了个错
data:image/s3,"s3://crabby-images/dbc5e/dbc5ee22f453f88858bb929e66ada647fb342606" alt=""
core-js@2.6.12: core-js@❤️.23.3 is no longer maintained and not recommended for usage due to the number of issues. Because of the V8 engine whims, feature detection in old core-js versions could cause a slowdown up to 100x even if nothing is polyfilled. Some versions have web compatibility issues. Please, upgrade your dependencies to the actual version of core-js.
出现这个问题先看看有没有使用淘宝的镜像,或者使用过期的淘宝镜像
查看镜像地址,使用如下命令:
powershell
npm config get registry
data:image/s3,"s3://crabby-images/83a26/83a26ad91335566e67e0e6c525fe2107846eeb34" alt=""
可以看到我这里还是默认的镜像地址,改为淘宝镜像的地址,这是最新的地址,地址如下:
命令如下:
powershell
npm config set registry https://registry.npmmirror.com
data:image/s3,"s3://crabby-images/3c4a6/3c4a69f0a118ee961027f0f060f79c6c4eeb4bb6" alt=""
如果看到几年前的教程,可能淘宝镜像的地址是这样:
这个地址不能用了!!!
这个地址不能用了!!!
这个地址不能用了!!!
重要的事情说三遍,别问我怎么知道的。。。
如果是在近期看到这篇博客,可以用我前面的地址,如果几年后看到,建议先搜索一下最新的淘宝镜像地址。
回到正题,为了试试效果,这里删除 node_modules
data:image/s3,"s3://crabby-images/a7436/a7436f39b25a8f8fd9370eeabad2b354e20b0022" alt=""
重新下载
powershell
npm install
data:image/s3,"s3://crabby-images/e276d/e276d28cb26366ce980c631a1c1a5bf5e3171a6e" alt=""
如果此时卡在这里
data:image/s3,"s3://crabby-images/ccd0c/ccd0c52a5e738e71755749022d1db4fe654ed9a6" alt=""
core-js@2.6.12: core-js@❤️.23.3 is no longer maintained and not recommended for usage due to the number of issues. Because of the V8 engine whims, feature detection in old core-js versions could cause a slowdown up to 100x even if nothing is polyfilled. Some versions have web compatibility issues. Please, upgrade your dependencies to the actual version of core-js.
Ctrl + C 退出,此应该升级 core-js 了,命令如下:
powershell
npm i core-js
data:image/s3,"s3://crabby-images/471c1/471c1b8b66d2e1454d84a46d0ba9a962127c4fc8" alt=""
然后再删除 node_modules ,重新下载
powershell
npm install
data:image/s3,"s3://crabby-images/8d1a1/8d1a12a6473916cb4534a572dc907165904d9614" alt=""
完成
2、启动项目
先看看能不能启动,先使用如下命令查看启动命令
powershell
npm run
data:image/s3,"s3://crabby-images/1ed1a/1ed1afbb954597ed68a4d9ccf4fa385c84648858" alt=""
所以启动命令为:
powershell
npm run serve
data:image/s3,"s3://crabby-images/2e2c3/2e2c3d7adc213a079f751654c4dfdbc222e8932e" alt=""
如果启动报如下错:
data:image/s3,"s3://crabby-images/19ff6/19ff6af11341d01c9445c826cc13c34352143445" alt=""
Error: error:0308010C:digital envelope routines::unsupported
这是因为 node 的版本高了,从图中可以看到我的 node 版本为 18 ,换回 17 及以下的版本即可解决。
也可以使用如下命令:
powershell
$env:NODE_OPTIONS="--openssl-legacy-provider"
data:image/s3,"s3://crabby-images/a30e5/a30e52dde4e235015766bc5f66f2bb318742cc63" alt=""
然后重新启动
powershell
npm run serve
data:image/s3,"s3://crabby-images/29bff/29bff862d4d322706fb79892132662181ef07361" alt=""
启动成功
3、打包
先试试能不能成功打包,命令如下:
powershell
npm run build
如果出现如下错:
data:image/s3,"s3://crabby-images/1a9d2/1a9d29f1ae1cbb15fcb4397d25b040bf0d902207" alt=""
Error: Cannot find module 'imagemin-gifsicle'
需要删除 node_modules 中的 image-webpack-loader
然后使用如下命令更新下载:
powershell
cnpm install --save-dev image-webpack-loader
data:image/s3,"s3://crabby-images/13091/13091af7d6af74dcc5def640198c48e5ad94e6a2" alt=""
如果使用命令报错
data:image/s3,"s3://crabby-images/68573/685739b688ab5f6db2754d2e3aac3d3fcdd11789" alt=""
cnpm : 无法加载文件 C:\Users\33530\AppData\Roaming\npm\cnpm.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.com/fwlink/?LinkID=135170 中的 about_Execution_Poli
cies。
千万不能使用 npm install --save-dev image-webpack-loader 下载,如果使用此命令下载不会报错,看起来是成功了,但是打包会报错。。。
别试了,我已经试过了,不行
此时应该以管理员的身份打开命令行窗口,输入如下命令
powershell
set-ExecutionPolicy RemoteSigned
data:image/s3,"s3://crabby-images/5a898/5a898874d47a4357afc73ed84992b0a93da1eac7" alt=""
然后安装 cnpm ,命令如下:
powershell
npm install -g cnpm --registry=https://registry.npmmirror.com
data:image/s3,"s3://crabby-images/ee2fb/ee2fb710e6693c5e0050e1aa586fd219abd60828" alt=""
我这里因为安装过了,所以比较快,安装完成后再使用如下命令:
powershell
cnpm install --save-dev image-webpack-loader
下载完成后再次打包
powershell
npm run build
data:image/s3,"s3://crabby-images/e33f6/e33f672a4549ba063bde661013bef92b5b69f448" alt=""
打包成功