接上篇。 angular项目打包命令,可以查看package.json的scripts内容。
"scripts": {
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
执行打包命令npm build后,即可生成打包文件夹www。 data:image/s3,"s3://crabby-images/5123f/5123f23d6036fe4564a6377f221c4730a9442cdb" alt="在这里插入图片描述"
问题1:
用浏览器打开www中的index.html文件,一些js文件报错: Access to script at ‘file:///runtime.js’ from origin ‘null’ has been blocked by CORS policy: Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, chrome-untrusted, https. data:image/s3,"s3://crabby-images/7ce6c/7ce6cd6a4635ff0b0148e38bbf963bf2ad895bfd" alt="在这里插入图片描述"
解决:
跨域问题,使用chrome浏览器的,可以先把浏览器进行跨域(可以百度一下,很多文章,这里不做赘述),然后再进行访问。
问题2:
在跨域后的chrome浏览器中访问www中的index.html文件,依然有资源文件报错 :net::ERR_FILE_NOT_FOUNDdata:image/s3,"s3://crabby-images/6e962/6e962be06b53cb217672d0ee1fe3f3e77d19ab2a" alt="在这里插入图片描述"
解决:
打开开发人员工具,查看network,就可以看到报net::ERR_FILE_NOT_FOUND是因为资源文件路径不对。 data:image/s3,"s3://crabby-images/455eb/455ebb29dbf76e87b3ec104db279944a30ef8959" alt="在这里插入图片描述" 需要修改打包后文件访问路径,两种方法: 方法一:改src/index.html
将 <base href="/" /> 改为 <base href="./" />
data:image/s3,"s3://crabby-images/f14e1/f14e199c950cdb24ca04befdbdc58fdbc802a446" alt="在这里插入图片描述" 方法二: 改package.json的scripts的build,添加–base-href ./
"build": "ng build --base-href ./",
data:image/s3,"s3://crabby-images/0f566/0f5664145cc99620fa1d9ea1438f20b6e6fd1b2a" alt="在这里插入图片描述" 两种方法都可,修改完成后,再次执行打包命令npm build,查看。
|