Vue应用部署到服务器的正确方式

服务器
页面出现空白现象,获取资源路径不对等,我相信以VueJs为技术栈来进行前端开发的小伙伴或多或少都会遇到这样的问题,我也遇到过,那现在我们就来一一解决这样的问题。

很多时候我们发现辛辛苦苦写的VueJs应用经过打包后在自己本地搭建的服务器上测试没有什么问题,但真正放在服务器上后,会发现或多或少的问题,比如:页面出现空白现象,获取资源路径不对等,我相信以VueJs为技术栈来进行前端开发的小伙伴或多或少都会遇到这样的问题,我也遇到过,那现在我们就来一一解决这样的问题。

[[269187]]

如何打包

  • 基于Vue-Cli,通过npm run build来进行打包的操作

如何部署

  • 将打包出来的资源,基于Vue-Cli的一般是dist目录下有static目录和index.html文件,可以直接将这两个文件扔到服务端
  • 但有时候,我们会直接将dist文件扔到服务端

出现的问题

  • 打包到服务器后,出现资源引用路径的问题
  • 打包到服务器后,出现空白页的问题
  • 打包到服务器后,出现引入的css的type被拦截转换为"text/plain"问题
  • 打包到服务器后,出现路由刷新404的问题

出现资源引用路径的解决方案

一般这个问题是由于在webpack配置打包发布的目录造成的。

  • 情况一.如果是将static与index.html直接放在服务器根目录,也就是说,当前的应用访问的网址如:http://www.abc.com
  • 解决办法:
  1. 配置输出的publiPath:"/"或者"./" 
  • 情况二.直接将打包后的dist文件放在了服务器的根目录,也就是如果需要访问当前的应用,访问的网址如:http://www.abc.com/dist
  • 解决办法:
  • 首先需要在创建路由实例中增加:
  1. const router = new VueRouter({ 
  2.  
  3. mode: 'history'
  4.  
  5. base: '/mobile/'
  6.  
  7. scorllBehavior: () => ({ 
  8.  
  9. y: 0 
  10.  
  11. }), 
  12.  
  13. routes 
  14.  
  15. }); 

然后再打包发布目录:

  1. publiPath:"/dist/"或者"http://www.abc.com/dist/" 

出现由于路由的history模式下刷新当前路由出现404的问题

今天做的应用发布到服务器上,发现当刷新当前路由的时候,就会出现404的状况,其实这是

因为当刷新当前页面时候,所需要访问的资源在服务器上找不到,也就是说,我们在VueJs开发应用的过程中,设置路由的路径不是真实存在的路径,并且使用了history模式。

  • 解决办法

需要后端进行配合,参考https://router.vuejs.org/en/essentials/history-mode.html

出现引入的css的type被拦截转换为"text/plain"问题

这是我开发过程中遇到的感觉很奇葩的问题,我们都知道,一般基于Vue-Cli,通过WebPack打包后的资源不需要更改什么。可是我发现,当我把代码进行上传后,输入网址,看见的页面把我吓坏了,发现所有样式不存在了,第一反应就是认为是自己在进行打包配置过程中出现了什么问题,然后通过fillder进行调试,发现css文件是正确获取到的。 

Vue应用部署到服务器的正确方式

可以看到,这个css文件的type被拦截转换为"text/plain",这时候,我又把相关的配置文件看了两遍,后面发现,真的是不好用啊,让我哭一会儿。先上图: 

 

Vue应用部署到服务器的正确方式

 

我擦,原来是服务器端返回的类型居然是"text/plain"。这个问题很好解决,把这图直接给后端,是不是感觉被坑了/(ㄒoㄒ)/~~。

 

责任编辑:武晓燕 来源: 今日头条
相关推荐

2018-03-12 09:13:12

应用程序服务器部署

2019-10-21 11:00:29

微服务架构部署策略

2018-06-13 10:27:04

服务器性能优化

2010-04-02 11:08:30

惠普服务器选购

2018-05-28 10:32:38

数据中心服务器布线

2021-08-07 21:51:17

服务器网站部署

2023-01-12 22:00:48

2009-01-07 18:32:53

服务器网络技术

2010-05-04 14:10:00

Media Servi

2010-07-05 14:28:37

SQL Server

2010-08-16 17:36:48

DB2连接服务器

2010-01-25 11:29:33

Android计时器

2016-08-09 19:36:48

2009-02-27 14:33:00

服务器软件企业服务器软件

2017-11-10 08:58:49

Web服务器应用程序

2009-09-17 11:59:29

WSUS服务器

2018-02-01 09:13:33

网站空间服务器

2010-04-30 17:30:21

Server 2008流媒体

2010-09-25 15:30:10

虚拟化

2012-02-23 10:02:08

Web服务器应用服务器
点赞
收藏

51CTO技术栈公众号