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


Posted in Javascript onJuly 15, 2017

本文介绍了Vue应用部署到服务器,分享给大家,希望此文章对各位有所帮助。

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

如何打包

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

如何部署

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

出现的问题

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

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

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

情况一.如果是将static与index.html直接放在服务器根目录,也就是说,当前的应用访问的网址如:http://www.xxx.com

解决办法:

配置输出的publiPath:"/"或者"./"

情况二.直接将打包后的dist文件放在了服务器的根目录,也就是如果需要访问当前的应用,访问的网址

如:http://www.xxx.com/dist

解决办法:

首先需要在创建路由实例中增加:

const router = new VueRouter({
mode: 'history',
base: '/mobile/',
scorllBehavior: () => ({
y: 0
}),
routes
});

然后再打包发布目录:

publiPath:"/dist/"或者"http://www.xxx.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ㄒ)/~~。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS array 数组详解
Mar 22 Javascript
javascript 事件绑定问题
Jan 01 Javascript
JavaScript作用域链使用介绍
Aug 29 Javascript
两款JS脚本判断手机浏览器类型跳转WAP手机网站
Oct 16 Javascript
JS实现左右无缝轮播图代码
May 01 Javascript
微信小程序 加载 app-service.js 错误解决方法
Oct 12 Javascript
详解angularjs中的隔离作用域理解以及绑定策略
May 31 Javascript
微信小程序 转发功能的实现
Aug 04 Javascript
vue-music 使用better-scroll遇到轮播图不能自动轮播问题
Dec 03 Javascript
JavaScript时间与时间戳的转换操作实例分析
Dec 07 Javascript
Vue 实现CLI 3.0 + momentjs + lodash打包时优化
Nov 13 Javascript
Windows下安装 node 的版本控制工具 nvm
Feb 06 Javascript
js+html5实现侧滑页面效果
Jul 15 #Javascript
angular2 ng build部署后base文件路径问题详细解答
Jul 15 #Javascript
Angular2关于@angular/cli默认端口号配置的问题
Jul 15 #Javascript
js编写简单的计时器功能
Jul 15 #Javascript
深入理解angular2启动项目步骤
Jul 15 #Javascript
js+html5实现复制文字按钮
Jul 15 #Javascript
js+html5实现页面可刷新的倒计时效果
Jul 15 #Javascript
You might like
Get或Post提交值的非法数据处理
2006/10/09 PHP
PHP中路径问题的解决方案
2006/10/09 PHP
解析获取优酷视频真实下载地址的PHP源代码
2013/06/26 PHP
php类的扩展和继承用法实例
2015/06/20 PHP
checkbox全选/取消全选以及checkbox遍历jQuery实现代码
2009/12/02 Javascript
jquery 经典动画菜单效果代码
2010/01/26 Javascript
jQuery.extend()、jQuery.fn.extend()扩展方法示例详解
2014/05/08 Javascript
jQuery对象和DOM对象之间相互转换的方法介绍
2015/02/28 Javascript
DeviceOne 让你一见钟情的App快速开发平台
2016/02/17 Javascript
angularjs定时任务的设置与清除示例
2017/06/02 Javascript
jquery dataTable 后台加载数据并分页实例代码
2017/06/07 jQuery
[js高手之路]HTML标签解释成DOM节点的实现方法
2017/08/31 Javascript
jQuery阻止事件冒泡实例分析
2018/07/03 jQuery
JavaScript+Canvas实现彩色图片转换成黑白图片的方法分析
2018/07/31 Javascript
angular2组件中定时刷新并清除定时器的实例讲解
2018/08/31 Javascript
[38:21]2018DOTA2亚洲邀请赛3月30日 小组赛A组 LGD VS Newbee
2018/03/31 DOTA
python目录操作之python遍历文件夹后将结果存储为xml
2014/01/27 Python
Python编程之字符串模板(Template)用法实例分析
2017/07/22 Python
python使用jieba实现中文分词去停用词方法示例
2018/03/11 Python
django框架实现一次性上传多个文件功能示例【批量上传】
2019/06/19 Python
python动态文本进度条的实例代码
2020/01/22 Python
Matplotlib中rcParams使用方法
2021/01/05 Python
CSS3 :not()选择器实现最后一行li去除某种css样式
2016/10/19 HTML / CSS
印度网上购物首选目的地:Flipkart
2016/08/01 全球购物
Parts Express:音频、视频和扬声器的第一来源
2017/04/25 全球购物
Bloomingdale’s阿联酋:选购奢华时尚、美容及更多
2020/09/22 全球购物
运动会稿件100字
2014/02/21 职场文书
中学清明节活动总结
2014/07/04 职场文书
2014教师党员自我评议总结
2014/09/19 职场文书
大学生上课迟到检讨书
2014/10/15 职场文书
项目负责人岗位职责
2015/02/15 职场文书
2015年公务员个人工作总结
2015/04/24 职场文书
2016年父亲节寄语
2015/12/04 职场文书
史上最全的军训拉歌口号
2015/12/25 职场文书
Python+Appium新手教程
2021/04/17 Python
Python3的进程和线程你了解吗
2022/03/16 Python