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 相关文章推荐
jquery fancybox ie6不显示关闭按钮的解决办法
Dec 25 Javascript
jquery live()调用不存在的解决方法
Feb 26 Javascript
jquery实现点击文字可编辑并修改保存至数据库
Apr 15 Javascript
js实现文本框中输入文字页面中div层同步获取文本框内容的方法
Mar 03 Javascript
jQuery隐藏和显示效果实现
Apr 06 Javascript
AngularJS路由实现页面跳转实例
Mar 03 Javascript
浅谈vue+webpack项目调试方法步骤
Sep 11 Javascript
react实现antd线上主题动态切换功能
Aug 12 Javascript
详解JavaScript中的Object.is()与"==="运算符总结
Jun 17 Javascript
详解小程序横屏方案对比
Jun 28 Javascript
uniapp实现横向滚动选择日期
Oct 21 Javascript
ant design vue导航菜单与路由配置操作
Oct 28 Javascript
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中计算中文字符串长度、截取中文字符串的函数代码
2011/08/09 PHP
PDO防注入原理分析以及使用PDO的注意事项总结
2014/10/23 PHP
PHP输入流php://input实例讲解
2015/12/22 PHP
php htmlentities()函数的定义和用法
2016/05/13 PHP
PHP上传Excel文件导入数据到MySQL数据库示例
2016/10/25 PHP
详解php语言最牛掰的Laravel框架
2017/11/20 PHP
关于html+ashx开发中几个问题的解决方法
2011/07/18 Javascript
js中parseFloat(参数1,参数2)定义和用法及注意事项
2013/01/27 Javascript
js如何获取file控件的完整路径具体实现代码
2013/05/15 Javascript
js防止表单重复提交的两种方法
2013/09/30 Javascript
第一次接触神奇的Bootstrap导航条
2016/08/09 Javascript
关于微信上网页图片点击全屏放大效果
2016/12/19 Javascript
ES6中Array.includes()函数的用法
2017/09/20 Javascript
移动端网页开发调试神器Eruda的介绍与使用技巧
2017/10/30 Javascript
解决nuxt页面中mounted、created、watch执行两遍的问题
2020/11/05 Javascript
[46:47]2014 DOTA2国际邀请赛中国区预选赛5.21 LGD-CDEC VS NE
2014/05/22 DOTA
flask中使用SQLAlchemy进行辅助开发的代码
2013/02/10 Python
python在命令行下使用google翻译(带语音)
2014/01/16 Python
Python反射用法实例简析
2017/12/22 Python
浅谈pyqt5中信号与槽的认识
2019/02/17 Python
利用Python查看微信共同好友功能的实现代码
2019/04/24 Python
安装Pycharm2019以及配置anconda教程的方法步骤
2019/11/11 Python
使用 Python ssh 远程登陆服务器的最佳方案
2020/03/06 Python
python 爬虫如何实现百度翻译
2020/11/16 Python
Alpine安装Python3依赖出现的问题及解决方法
2020/12/25 Python
英国屋顶用品和材料超市:Roofing Supplies UK
2019/08/24 全球购物
实习指导老师评语
2014/04/26 职场文书
求职自荐信范文(优秀篇)
2015/03/27 职场文书
帝企鹅日记观后感
2015/06/10 职场文书
国家助学金受助感言
2015/08/01 职场文书
学生病假条范文
2015/08/17 职场文书
2016年第32个教师节红领巾广播稿
2015/12/18 职场文书
祝福语集锦:给满月宝宝的祝福语
2019/11/20 职场文书
golang中的空接口使用详解
2021/03/30 Python
如何利用Python实现n*n螺旋矩阵
2022/01/18 Python
Win10/Win11 任务栏替换成经典样式
2022/04/19 数码科技