前端Vue项目打包部署实战教程

简介: 前言在前后端还没有分离的时代下,前端项目通常时放在后端项目的静态资源目录下一起部署的,那个时候并没有专门的前端程序员,或者也可以说前端程序员不需要自己部署网站。通常前端人员只需要把网站源文件如.html文件结尾的资源包发给后端或者运维即可,剩下的事便交给后端或运维搞定了。但是前后端分离开发后,前后端项目也通常分离部署了,这个时候可能就需要前端人员自己部署前端项目,然后前端人员可能很少接触到服务器等知识,所以部署网站时总是捉襟见肘。这边文章主要就是讲解如何将一个前端项目部署到服务器,并且外网可以访问,前端项目就以Vue项目为例。

1.准备工作


  • 完整的Vue项目
  • 一台服务器


准备工作很简单,只需要一个项目和一台服务器即可,项目甚至可以只是一个html文件。


2.初始化Vue项目



使用Vue-cli脚手架初始化一个最基本的Vue项目,命令如下:

vue create myproject

我们初始化一个Vue2.0的项目,选好配置后一路回车:

17.png


运行命令:


npm run serve


项目运行成功:

18.png


3.服务器安装Nginx


Nginx是一款轻量级的Web服务器、反向代理服务器,由于它的内存占用少,启动极快,高并发能力强,在互联网项目中广泛应用,我们的网站部署到Nginx服务器上。当然也可以选择其它web服务器,这里我们就使用主流的Nginx。


我这里的服务器是Centos系统,故已Centos为例。


(1)先查看服务器是否有nginx

命令如下:

whereis nginx

如果出现如下界面,则代表未安装nginx,否则可跳过本节。19.png


(2)安装nginx

命令如下:

yum install -y nginx


如果未配置yum源的,可参考网上如何使用yum安装nginx,出现如下界面则代表安装完成。20.png


(3)查看nginx安装目录

命令如下:

whereis nginx


21.png


或者使用命令查看nginx版本号,出现版本号也代表安装成功。

输入命令:

nginx -v

22.png

如果不能全局使用nginx指令,那么可能是环境变量没有配置,具体配置方法可参考网上,这里不做过多解释。


4.启动nginx


(1)启动

服务器安装号nginx后,我们尝试启动它、

命令如下:

nginx

23.png

直接输入nginx即可启动服务,打开浏览器,访问服务器地址,出现如下界面则代表启动成功。

24.png

这里访问默认的是80端口,因为nginx服务就是默认的80端口,如果不能访问,大致有几种原因:

  • nginx未启动
  • 服务器安全组未加入80端口
  • nginx配置错误


(2)停止

停止nginx服务,命令如下:

nginx -s stop

此时访问浏览器则无法访问:25.png


(3)重启

重启nginx服务,一般用于修改配置文件之后,命令如下:

nginx -s reload



5.修改nginx配置


找到nginx配置文件存放位置,命令如下:

whereis nginx

23.png

此时/etc/nginx则是nginx配置文件存放位置,进入该文件夹:224.png


nginx.conf则是默认配置文件,编辑该文件:

网络异常,图片无法展示
|



上面界面我们基本上不用改什么,重要的是server这个对象,可以看到默认监听的是80端口,所以我们直接访问服务器ip即可,接下来我们改为9000端口:2.png

重启nginx,命令如下:

nginx -s reload

此时访问时则需要带上端口号(需要服务器安全组开启9000端口),访问地址:http://ip:9000


3.png

我们还需要注意的一个地方就是root字段,该字段后面跟着的就是网站页面路径,也就是网站存放的路径。

假设我们网站的存放路径为:

/home/www/dist


修改root,结果如下:4.png

这个时候重启nginx,我们的网站无法访问了,因为我们没有这个文件夹。

5.png

6.新建网站文件夹


刚刚我们设置了网站存放的文件夹路径为:

/home/www/dist



此时我们需要在服务器上新建www文件夹:

cd /home
mkdir www

6.png

我们没有新建dist文件夹,因为我们待会儿vue项目打包就会生成dist文件夹。


7.打包部署vue项目


(1)打包网站

使用vue打包命令,生成dist文件夹:

npm run build


(2)上传至服务器

我们可以使用ftp工具将dist文件夹上传至/home/www目录下,当然也可以使用命令:

scp -r dist/ root@139.9.219.136:/home/www



7.png


在我们的项目目录下用打开git命令行,将本地的dist整个文件夹复制到服务器,需要主要的时scp命令window不支持,所以使用了git命令行工具。

此时无需重启nginx,刷新浏览器,可以看到我们的网站已经部署成功了。


8.png


8.解决刷新路由404问题

当我们切换路由后,然后在刷新页面,会出现404的情况。

网络异常,图片无法展示
|



这是因为我们vue项目采用了history的路由方式,至于原因主要是vue是单页面应用,细节部分大家可自行下来了解。


解决问题的办法:


(1)将路由模式改为hash

(2)修改nginx配置:

location / {
  try_files $uri $uri/ /index.html; ---解决页面刷新404问题
} 

9.png

修改之后重启nginx,这个时候刷新浏览器则不会出现404了。


总结


网站部署其实很简单,主要是需要了解nginx知识,懂了基本原理之后,部署任何网站都不会有问题的。


小编开源网站:小猪导航

相关文章
|
7月前
|
JavaScript 前端开发 Java
制造业ERP源码,工厂ERP管理系统,前端框架:Vue,后端框架:SpringBoot
这是一套基于SpringBoot+Vue技术栈开发的ERP企业管理系统,采用Java语言与vscode工具。系统涵盖采购/销售、出入库、生产、品质管理等功能,整合客户与供应商数据,支持在线协同和业务全流程管控。同时提供主数据管理、权限控制、工作流审批、报表自定义及打印、在线报表开发和自定义表单功能,助力企业实现高效自动化管理,并通过UniAPP实现移动端支持,满足多场景应用需求。
675 1
|
3月前
|
前端开发 JavaScript 应用服务中间件
在Docker部署的前端应用中使用动态环境变量
以上步骤展示了如何在 Docker 配置过程中处理并注入环墨遁形成可执行操作流程,并确保最终用户能够无缝地与之交互而无须关心背后复杂性。
195 13
|
2月前
|
JavaScript 安全
vue3使用ts传参教程
Vue 3结合TypeScript实现组件传参,提升类型安全与开发效率。涵盖Props、Emits、v-model双向绑定及useAttrs透传属性,建议明确声明类型,保障代码质量。
289 0
|
8月前
|
移动开发 前端开发 JavaScript
Vue与React两大前端框架的主要差异点
以上就是Vue和React的主要差异点,希望对你有所帮助。在选择使用哪一个框架时,需要根据项目的具体需求和团队的技术栈来决定。
496 83
|
8月前
|
前端开发 Java 物联网
智慧班牌源码,采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署
智慧班牌系统是一款基于信息化与物联网技术的校园管理工具,集成电子屏显示、人脸识别及数据交互功能,实现班级信息展示、智能考勤与家校互通。系统采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署与私有化定制。核心功能涵盖信息发布、考勤管理、教务处理及数据分析,助力校园文化建设与教学优化。其综合性和可扩展性有效打破数据孤岛,提升交互体验并降低管理成本,适用于日常教学、考试管理和应急场景,为智慧校园建设提供全面解决方案。
526 70
|
7月前
|
JavaScript 前端开发 编译器
Vue与TypeScript:如何实现更强大的前端开发
Vue.js 以其简洁的语法和灵活的架构在前端开发中广受欢迎,而 TypeScript 作为一种静态类型语言,为 JavaScript 提供了强大的类型系统和编译时检查。将 Vue.js 与 TypeScript 结合使用,不仅可以提升代码的可维护性和可扩展性,还能减少运行时错误,提高开发效率。本文将介绍如何在 Vue.js 项目中使用 TypeScript,并通过一些代码示例展示其强大功能。
307 22
|
6月前
|
JavaScript 前端开发 UED
Vue 项目中如何自定义实用的进度条组件
本文介绍了如何使用Vue.js创建一个灵活多样的自定义进度条组件。该组件可接受进度段数据数组作为输入,动态渲染进度段,支持动画效果和内容展示。当进度超出总长时,超出部分将以红色填充。文章详细描述了组件的设计目标、实现步骤(包括props定义、宽度计算、模板渲染、动画处理及超出部分的显示),并提供了使用示例。通过此组件,开发者可根据项目需求灵活展示进度情况,优化用户体验。资源地址:[https://pan.quark.cn/s/35324205c62b](https://pan.quark.cn/s/35324205c62b)。
277 0
|
9月前
|
人工智能 JavaScript 前端开发
Vue 性能革命:揭秘前端优化的终极技巧;Vue优化技巧,解决Vue项目卡顿问题
Vue在处理少量数据和有限dom的情况下技术已经非常成熟了,但现在随着AI时代的到来,海量数据场景会越来越多,Vue优化技巧也是必备技能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
存储 JavaScript Shell
vue项目打包后提交到git上为什么没有dist这个文件?
vue项目打包后提交到git上为什么没有dist这个文件?
vue项目打包后提交到git上为什么没有dist这个文件?
|
3月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
330 2

热门文章

最新文章

  • 1
    前端如何存储数据:Cookie、LocalStorage 与 SessionStorage 全面解析
    558
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    224
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    216
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    154
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    261
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    393
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    171
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    108
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    181
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    249