当前位置: 移动技术网 > IT编程>脚本编程>vue.js > Vue项目服务器部署之子目录部署方法

Vue项目服务器部署之子目录部署方法

2019年07月19日  | 移动技术网IT编程  | 我要评论

陕西电视台节目表,宋大德 新农村,王石女儿王蔚蓝照片

vue项目尤其是基于.vue单文件格式的项目部署,在build成js文件后发布到服务器上,一般都是通过nginx反向代理到跟文件目录后直接访问,然而由于很多时候没办法使用更多的子域名(比如微信公众号只能有一个域名),所以急需将服务器部署到子目录。本经验以一次成功的系统部署为例,讲解子目录方式部署vue工程。

首先介绍一下poi,我们的项目没有使用webpack进行前端工程项目管理,使用了poi进行管理:develop web apps with no build configuration until you need.也就是说poi对webpack进行了封装,0配置开发web应用。可以使用poi.config.js文件配置poi的配置,也可以直接在package.json中进行配置。

执行npm run dev相当于执行poi,执行npm run dist相当于执行poi build.执行poi build打包后,会将static目录下的资源拷贝到dist目录,其他的js和css会自动压缩成.js 和.css并且注入到中。

poi项目如果需要打包到子目录,必须设置homepage为子目录。这是第一步

第二步,必须将中其他非vue部分的资源增加子目录的前缀,包括网站的icon.

第三步保证css文件中的资源路径为相对路径。

第四步,需要修改vuerouter中的base为子目录。

然后执行npm run dev 也就是npm build.观察打包后的,css文件等。

然后配置nginx到二级目录:       

 location  /ticket {           alias /root/java/ticket/dist/;           try_files $uri $uri/ @rewrites;        }        location @rewrites {          rewrite ^/(ticket|sign|reimburse)/(.+)$ /$1/ last;        }这里$1对应url中的ticket,由于我这里有多个项目共用了rewrite所以逻辑或了三个,如果只有一个子目录,使用^/(ticket)/(

然后配置nginx到二级目录:        location  /ticket {           alias /root/java/ticket/dist/;           try_files $uri $uri/ @rewrites;        }        location @rewrites {          rewrite ^/(ticket|sign|reimburse)/(.+)$ /$1/ last;        }这里$1对应url中的ticket,由于我这里有多个项目共用了rewrite所以逻辑或了三个,如果只有一个子目录,使用^/(ticket)/(.+)$,这里切记要把ticket扩起来。

这里切记要把ticket扩起来。

项目部署成功!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网