编译构建 CodeArts Build-执行Npm构建时,报错提示JavaScript heap out of memory:处理方法
处理方法
方法一:升级nodejs版本。
方法二:启动Node时设置“--max_old_space_size”或“--max_new_space_size”参数来调整内存大小的使用限制。
node --max_old_space_size=1700 test.js // 单位为MB 修改老生代内存限制node --max_new_space_size=1024 test.js // 单位为KB 修改新生代内存限制
针对前端三大框架的解决方法如下:
框架类型 |
解决方法 |
---|---|
Vue |
只需要修改“package.json”文件中“build”属性值,在命令中加入带参数的node命令即可,例如: "build": "node --max_old_space_size=4096 ./node_modules/vite/bin/vite.js build" 或 "build": "node --max_old_space_size=4096 ./node_modules/@vue/cli-service/bin/vue-cli-service.js build" |
React |
举例说明“package.json”里面“scripts”字段的内容如下: "scripts": {"start": "react-scripts start","build": "react-scripts build","test": "react-scripts test --env=jsdom","eject": "react-scripts eject"} 运行npm run build的时候跑的实际代码是react-scripts build,项目根目录下“node_modules”文件夹,找到.bin目录并打开它找到“react-scripts”文件,打开这个文件,把--max_old_space_size=4096这行代码写在#!/usr/bin/env node后面: #!/usr/bin/env node --max_old_space_size=4096 |
Angular |
举例说明“package.json”里面“scripts”字段的内容如下: "scripts": {"ng": "ng","start": "ng serve","build": "ng build","test": "ng test","lint": "ng lint","e2e": "ng e2e"} 这里的ng命令也和React一样,在项目根目录“node_modules”文件夹下的.bin目录里面存在名为ng的文件,修改该文件的首行: #!/usr/bin/env node --max_old_space_size=4096 |