Vue打包上线服务器的坑及解决方法 时光大魔王

原文地址:原文地址

🙄 想必各位老大在Vue开发时都遇到过这种情况:
开发模式各项模块功能和代理都正常,但当满心欢喜地Build打包后上线服务器,却发现有一堆Bug,比如代理不生效、刷新页面变空白等情况 😂

接下来我将整理一些我遇到过的问题和自己常用的解决方法,望各位学习采纳,有不足和没提到的请在评论区里交流学习。原创文章,请勿抄袭!

前言

主要是Vue2,Vue3还没具体实操过,不过大致解决方案类似~【滑稽】

一、访问或刷新目标地址页面后显示空白或404

大家可能遇到过这种情况:上线后通过 router-link 标签或 $router.push 方法访问特定的地址页面正常显示,而刷新或者直接访问就会页面显示空白或404,就像这样:在这里插入图片描述

问题解析

vue是个单页应用,它的路由是模拟的url,并没有在服务器上真实存在,当然访问不到!

解决方法

第一种:前端

不推荐,个人感觉 hash 模式超级丑!
router/index.js 里更改 modehash
在这里插入图片描述

第二种:后端:

在服务器站点配置里添加:

location / {
	try_files $uri $uri/ /index.html;
}

在这里插入图片描述

二、devServer.proxy 跨域代理上线后不正常

开发模式时,我们设置里 devServer.proxy 跨域本地代理,且功能正常,但当我们更换 target 为 服务器后端接口地址上线后,却发现无法访问或者出现这种文字:
We’re sorry but myapp doesn’t work properly without JavaScript enabled. Please enable it to continue.
在这里插入图片描述

问题解析

Concise200 说:
因为在vue.config.js中配置的devServer.proxy只是在开发环境下将请求代理到后端服务器的本地服务,我们把项目打包成dist文件只把我们的组件等资源打包了,并不会将代理服务器给打包,所以项目中的请求路径不完整导致访问不到对应资源

解决方法

第一种:前端

把项目的所有网络请求的 url 都改成完整接口地址【画外音:这不就摸鱼理由来了嘛,滑稽】

其它方法似乎没有,大佬们如果有的话请分享~

第二种:后端:

在服务器站点配置里添加:
(注:配合问题一的解决方法的代码一起食用更香哟~)

location ^~/api/ {
	proxy_pass http://xxx.cn/;// 这里是你需要代理的后端接口地址
}

在这里插入图片描述

更多

还在搜集,遇到了再整理~

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

时光小灶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值