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 相关文章推荐
IE 缓存策略的BUG的解决方法
Jul 21 Javascript
判断脚本加载是否完成的方法
May 26 Javascript
ANT 压缩(去掉空格/注释)JS文件可提高js运行速度
Apr 15 Javascript
javascript模块化是什么及其优缺点介绍
Sep 02 Javascript
Egret引擎开发指南之视觉编程
Sep 03 Javascript
AngularJS基础 ng-paste 指令简单示例
Aug 02 Javascript
基于Particles.js制作超炫粒子动态背景效果(仿知乎)
Sep 13 Javascript
Vue框架之goods组件开发详解
Jan 25 Javascript
微信小程序云开发之数据库操作
May 18 Javascript
原生js实现二级联动菜单
Nov 27 Javascript
vue-cli创建的项目中的gitHooks原理解析
Feb 14 Javascript
jQuery实现鼠标滑动切换图片
May 27 jQuery
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
星际流派综述
2020/03/04 星际争霸
php+jquery编码方面的一些心得(utf-8 gb2312)
2010/10/12 PHP
php的ajax框架xajax入门与试用介绍
2010/12/19 PHP
解析file_get_contents模仿浏览器头(user_agent)获取数据
2013/06/27 PHP
教你在header中隐藏php的版本信息
2016/08/10 PHP
php中的钩子理解及应用实例分析
2019/08/30 PHP
suggestion开发小结以及对键盘事件的总结(针对中文输入法状态)
2011/12/20 Javascript
easyui datagrid 键盘上下控制选中行示例
2014/03/31 Javascript
JS验证逗号隔开可以是中文字母数字
2016/04/22 Javascript
Bootstrap每天必学之警告框插件
2016/04/26 Javascript
使用Bootstrap框架制作查询页面的界面实例代码
2016/05/27 Javascript
详解node如何让一个端口同时支持https与http
2017/07/04 Javascript
讲解vue-router之什么是嵌套路由
2018/05/28 Javascript
Bootstrap 模态框自定义点击和关闭事件详解
2018/08/10 Javascript
vue自定义js图片碎片轮播图切换效果的实现代码
2019/04/28 Javascript
vue实现菜单切换功能
2019/05/08 Javascript
laydate只显示时分 不显示秒的功能实现方法
2019/09/28 Javascript
Vue的状态管理vuex使用方法详解
2020/02/05 Javascript
如何手写简易的 Vue Router
2020/10/10 Javascript
vue中echarts的用法及与elementui-select的协同绑定操作
2020/11/17 Vue.js
[51:15]2014 DOTA2国际邀请赛中国区预选赛 Orenda VS LGD-GAMING
2014/05/22 DOTA
python+opencv实现阈值分割
2018/12/26 Python
python 图像平移和旋转的实例
2019/01/10 Python
python torch.utils.data.DataLoader使用方法
2020/04/02 Python
pip已经安装好第三方库但pycharm中import时还是标红的解决方案
2020/10/09 Python
美国最佳选择产品网站:Best Choice Products
2019/05/27 全球购物
写一个方法1000的阶乘
2012/11/21 面试题
印刷工程专业应届生求职信
2013/09/29 职场文书
俄罗斯商务邀请函
2014/01/26 职场文书
两只小狮子教学反思
2014/02/05 职场文书
超市促销活动方案
2014/03/05 职场文书
小学捐书活动总结
2014/07/05 职场文书
电子商务专业求职信范文
2015/03/19 职场文书
爱岗敬业先进典型事迹材料(2016推荐版)
2016/02/26 职场文书
文案策划岗位个人自我评价(范文)
2019/08/08 职场文书
为什么MySQL8新特性会修改自增主键属性
2022/04/18 MySQL