扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
这篇文章主要为大家展示了“如何实现vue本地打开build后生成dist文件夹index.html的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何实现vue本地打开build后生成dist文件夹index.html的问题”这篇文章吧。
成都创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于做网站、成都网站制作、安岳网络推广、小程序开发、安岳网络营销、安岳企业策划、安岳品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联公司为所有大学生创业者提供安岳建站搭建服务,24小时服务热线:18982081108,官方网址:www.cdcxhl.com
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
var express = require('express'); var app = express(); const hostname = 'localhost'; const port = 8080; app.use(express.static('./')); app.listen(port, hostname, () => { console.log(`Server running at http://${hostname}:${port}`); });
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 配置
var express = require('express'); var app = express(); const hostname = 'localhost'; const port = 8080;
//Express 提供了内置的中间件 express.static 来设置静态文件 app.use(express.static('./')); app.listen(port, hostname, () => { console.log(`Server running at http://${hostname}:${port}`); }); express.static('./')
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.js
以上是“如何实现vue本地打开build后生成dist文件夹index.html的问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流