时间:2021-05-26
1.问题描述:
npm run build 在dist 文件生成了 index 和 static 文件夹,为什么本地打开不了,给后端就能打开?
如何才能像访问 npm run dev 的地址那样访问?
2.种简单方法
2.1 修改配置在本地访问
更改一些路径参数后,然后再次运行npm run build 就可以在本地打开index.html
改哪里?
config/index.js文件
build: { assetsPublicPath: '/'}改成
build: { assetsPublicPath: './'}修改后再次运行 npm run build
双击 index.html 即可
2.2 通过在dist 目录中起服务访问
step1:
在dist 文件中添加 server.js
step 2:
在dist 路径下,npm install express
step 3:
node server
3.其他:
3.1 本地访问不足
如果ajax请求的数据是通过访问本地文件伪造的,那么会报跨域错误
不支持跨域读取本地data
本地访问路径如:
file:///Users/Downloads/vue-travel-master/dist/index.html
3.2 生产环境不支持proxyTable
config/index.js 中,只有开发环境dev中配置了proxyTable,支持访问代理路径
但是在 build 中配置无效,不支持代理地址
比如我在开发环境中请求数据
axios.get('/api/index.json?city=' + this.city)
开发环境的proxyTable:
proxyTable: { '/api': { target: 'http://localhost:8080', changeOrigin:true,//允许跨域 pathRewrite: { '^/api': '/static/mock' } }访问路径会替换成 http://localhost:8080/static/mock/index.json
但是生产环境不支持这样,路径要写全:
axios.get('/static/mock/index.json?city=' + this.city)
这样在dist目录下 node server 就可以访问了和 npm run dev 的效果是一模一样的!
起服务访问地址:
http://localhost:8080/static/js/app.5115f466b0f6ef56da51.js
3.3 express 配置
express 会在静态资源目录下查找文件,即server.js的上层路径dist目录,现在你可以加载dist 目录下的文件了,如:
http://localhost :8080/static/mock/index.json?city=%E4%B8%8A%E6%B5%B7
访问路径为:
——dist ——static ——css ——js ——mock ——a.json ——index.html ——server.js4. 代码
4.1 可运行代码链接
可下载运行试试
总结
以上所述是小编给大家介绍的vue本地打开build后生成的dist文件夹index.html问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
几种设置publicPath后,再对比打包后的index.html文件测试背景:每次打包build完后,都单独生成一个/dist文件夹,且dist中每次都只有相
使用npmrunbuild生成dist文件夹中的文件是你需要上传到服务器上的文件,直接打开index.html会直接报错可以尝试用express搭建一个服务器,
一、打包vue项目 在开发完的vue项目输入如下命名,打包生成dist文件夹yarnbuild/npmrunbuild 此时根目录会多出一个文件夹:dist
我们知道使用webpack打包vue项目后会生成一个dist文件夹,dist文件夹下有html文件和其他css、js以及图片等,那么打包后的文件该如何正确运
webpack打包后动画未执行,就是npmrunbuild后在dist中生成的项目中动画未生效解决:找到build文件夹中得vue-loader.conf.js