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 相关文章推荐
javascript在一段文字中的光标处插入其他文字
Aug 26 Javascript
HTML5使用DeviceOrientation实现摇一摇功能
Jun 05 Javascript
javascript实现label标签跳出循环操作
Mar 06 Javascript
Javascript基础_嵌入图像的简单实现
Jun 14 Javascript
Angular ng-class详解及实例代码
Sep 19 Javascript
JS实现的几个常用算法
Nov 12 Javascript
浅谈javascript中的数据类型转换
Dec 27 Javascript
bootstrap Validator 模态框、jsp、表单验证 Ajax提交功能
Feb 17 Javascript
vue 项目常用加载器及配置详解
Jan 22 Javascript
vue3.0 CLI - 2.2 - 组件 home.vue 的初步改造
Sep 14 Javascript
vue中v-show和v-if的异同及v-show用法
Jun 06 Javascript
JavaScript 正则应用详解【模式、欲查、反向引用等】
May 13 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
YB217、YB235、YB400浅听
2021/03/02 无线电
PHP 小心urldecode引发的SQL注入漏洞
2011/10/27 PHP
ThinkPHP3.1新特性之多层MVC的支持
2014/06/19 PHP
ThinkPHP3.1新特性之G方法的使用
2014/06/19 PHP
PHP开发框架laravel安装与配置教程
2015/03/13 PHP
在WordPress中安装使用视频播放器插件Hana Flv Player
2016/01/04 PHP
关于图片验证码设计的思考
2007/01/29 Javascript
javascript 用记忆函数快速计算递归函数
2010/03/15 Javascript
javascript制作的网页侧边弹出框思路及实现代码
2014/05/21 Javascript
jQuery读取XML文件内容的方法
2015/03/09 Javascript
css如何让浮动元素水平居中
2015/08/07 Javascript
Bootstrap 折叠(Collapse)插件用法实例详解
2016/06/01 Javascript
jquery ui sortable拖拽后保存位置
2017/04/27 jQuery
Angular2环境搭建具体操作步骤(推荐)
2017/08/04 Javascript
layui实现下拉复选功能的例子(包括数据的回显与上传)
2019/09/24 Javascript
uniapp实现可以左右滑动导航栏
2020/10/21 Javascript
解决Antd 里面的select 选择框联动触发的问题
2020/10/24 Javascript
vue keep-alive的简单总结
2021/01/25 Vue.js
python使用beautifulsoup从爱奇艺网抓取视频播放
2014/01/23 Python
在Python中使用Neo4j的方法
2019/03/14 Python
Python空间数据处理之GDAL读写遥感图像
2019/08/01 Python
Django中使用haystack+whoosh实现搜索功能
2019/10/08 Python
使用pyinstaller逆向.pyc文件
2019/12/20 Python
linux环境下安装python虚拟环境及注意事项
2020/01/07 Python
Python利用imshow制作自定义渐变填充柱状图(colorbar)
2020/12/10 Python
Html5实现文件异步上传功能
2017/05/19 HTML / CSS
新西兰演唱会和体育门票网站:Ticketmaster新西兰
2017/10/07 全球购物
Lime Crime官网:美国一家主打梦幻精灵系的彩妆品牌
2019/03/22 全球购物
Martinelli官方商店:西班牙皮鞋和高跟鞋品牌
2019/07/30 全球购物
装修设计师求职信
2014/02/26 职场文书
董事长秘书工作职责
2014/06/10 职场文书
暑期培训心得体会
2014/09/02 职场文书
学校政风行风评议心得体会
2014/10/21 职场文书
优秀教师工作总结2015
2015/07/22 职场文书
2015年社区国庆节活动总结
2015/07/30 职场文书
大学生活委员竞选稿
2015/11/21 职场文书