Vuejs+vue-router打包+Nginx配置的实例


Posted in Javascript onSeptember 20, 2018

其实这个网上已经有了很多人写了,为什么我还要再写这一篇博客?因为我亲身把他们生产的坑给踩了个通透(摊手。

正文开始

本次的项目是基于vue-cli生成的项目,采用的vue-router的history模式。到这里相信大部人还是类似了,接下来就是一个坑死人不偿命的网上诸多博客都在采用的巨坑。

在进行打包的时候,很多博客里都写了,将/config/index.js下,build中的assetsPublicPath从/改为./。我很后悔,为什么当初这样照做的时候不去思考为什么,为什么要这样做,凭什么?如果这个有问题为什么webpack生成的时候不改反而一直放在那里?是谁傻?问题先放在这里,我们先按照那些教程走。修改完后npm run build,这样在你的项目下就生成了一个dist文件夹,里面就是生成的静态内容。假设现在你的dist文件夹已经在你的云服务器中了。接下来开始nginx的配置。

个人采用的是sudo apt-get install nginx安装的nginx,现在在命令行下,

cd /etc/nginx/conf.d/, 并在该目录下 sudo touch vueSite.conf,接下来修改该文件内容。

server {
 listen 3000; # 假设你项目监听的是3000端口
 root /path/to/dist;
 location / {
  try_files $uri $uri/ /index.html;
 }
}

然后

sudo nginx -t检查正确性,无误后sudo nginx -s reload。

接下来在你的浏览器下访问cloudserverhost:3000,就可以访问到你的项目主页了。

目前来看似乎是一切顺利呢,网上的教程真棒棒哦~

然后你可以试试,在cloudserverhost:3000/path/subpath下刷新试试,你会发现,页面没有了,浏览器器里会报错,你会发现请求的js/css等都变成了html页面的内容。这个问题就是出在了./下,我不知道第一个这样写出来的人他的项目是不是很幸运的只有一级路径,又或者他从来不会尝试去刷新页面,否则这个问题是无可避免的,为什么呢?./是相对路径,/则是绝对路径,当你在二级路径下刷新重新请求资源,你的请求路径是什么?把请求路径写出来我们就会发现问题出在哪里了。很难过,我写这篇博客只用不到10分钟,找到这个问题却用了差不多10小时,查了各种方法,我真是万万没想到。

因此,正式上线的项目,没有必要修改/config/index.js下,build中的assetsPublicPath。配置好nginx,你的项目就可以开始起飞了!

以上这篇Vuejs+vue-router打包+Nginx配置的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用javascript实现的激活输入框后隐藏初始内容
Jun 29 Javascript
js取两个数组的交集|差集|并集|补集|去重示例代码
Aug 07 Javascript
jQuery 仿百度输入标签插件附效果图
Jul 04 Javascript
利用jQuery的动画函数animate实现豌豆发射效果
Aug 28 Javascript
JS实现鼠标滑过显示边框的菜单效果
Sep 21 Javascript
微信小程序 animation API详解及实例代码
Oct 08 Javascript
js判断文件格式及大小的简单实例(必看)
Oct 11 Javascript
基于vue,vue-router, vuex及addRoutes进行权限控制问题
May 02 Javascript
详解.vue文件中style标签的几个标识符
Jul 17 Javascript
了解在JavaScript中将值转换为字符串的5种方法
Jun 06 Javascript
js实现简单分页导航栏效果
Jun 28 Javascript
vue 在单页面应用里使用二级套嵌路由
Dec 19 Vue.js
vue中接口域名配置为全局变量的实现方法
Sep 20 #Javascript
vue-cli项目无法用本机IP访问的解决方法
Sep 20 #Javascript
vue项目中,main.js,App.vue,index.html的调用方法
Sep 20 #Javascript
解决vue脚手架项目打包后路由视图不显示的问题
Sep 20 #Javascript
微信小程序onLaunch异步,首页onLoad先执行?
Sep 20 #Javascript
vue3.0 CLI - 3.2 路由的初级使用教程
Sep 20 #Javascript
微信小程序使用gitee进行版本管理
Sep 20 #Javascript
You might like
PHP使用者状态管理功能的应用
2006/10/09 PHP
php版微信公众平台回复中文出现乱码问题的解决方法
2016/09/22 PHP
PHP常量DIRECTORY_SEPARATOR原理及用法解析
2020/11/10 PHP
070823更新的一个[消息提示框]组件 兼容ie7
2007/08/29 Javascript
JavaScript 给汉字排序实例代码
2008/06/28 Javascript
zShowBox 图片放大展示jquery版 兼容性
2011/09/24 Javascript
基于javascript实现浏览器滚动条快到底部时自动加载数据
2015/11/30 Javascript
JS组件Bootstrap导航条使用方法详解
2016/04/29 Javascript
EasyUI在表单提交之前进行验证的实例代码
2016/06/24 Javascript
关于Function中的bind()示例详解
2016/12/02 Javascript
Node.js的Mongodb使用实例
2016/12/30 Javascript
jQuery布局组件EasyUI Layout使用方法详解
2017/02/28 Javascript
AngularJS 最常用的八种功能(基础知识)
2017/06/26 Javascript
VUE项目中加载已保存的笔记实例方法
2019/09/14 Javascript
对vue中的事件穿透与禁止穿透实例详解
2019/10/28 Javascript
在vue中使用echars实现上浮与下钻效果
2019/11/08 Javascript
javascript操作向表格中动态加载数据
2020/08/27 Javascript
vue修改Element的el-table样式的4种方法
2020/09/17 Javascript
[15:20]DOTA2-DPC中国联赛 正赛 Elephant vs Aster 选手采访
2021/03/11 DOTA
[46:20]DOTA2-DPC中国联赛 正赛 PSG.LGD vs LBZS BO3 第二场 1月22日
2021/03/11 DOTA
Python中对象的引用与复制代码示例
2017/12/04 Python
Python标准库inspect的具体使用方法
2017/12/06 Python
python编程使用协程并发的优缺点
2018/09/20 Python
说说如何遍历Python列表的方法示例
2019/02/11 Python
基于python检查SSL证书到期情况代码实例
2020/04/04 Python
Pytest如何使用skip跳过执行测试
2020/08/13 Python
python实现定时发送邮件
2020/12/23 Python
Argos官网:英国家喻户晓的百货零售连锁商
2017/04/03 全球购物
经济实惠的豪华家具:My-Furniture
2019/03/12 全球购物
法国女性内衣购物网站:Glamuse
2019/05/13 全球购物
linux面试题参考答案(8)
2016/04/19 面试题
中专生职业生涯规划书范文
2013/12/29 职场文书
安全生产协议书
2016/03/22 职场文书
2016年保险公众宣传日活动总结
2016/04/05 职场文书
Windows11里微软已经将驱动程序安装位置A盘删除
2021/11/21 数码科技
Vue Element plus使用方法梳理
2022/12/24 Vue.js