当前位置:   article > 正文

vue项目打包部署到服务器,Vue项目打包部署到apache服务器的方法步骤

vue 打包后部署到phpstudy apache

vue项目在开发环境下,让项目运行起来,是通过npm run dev命令,原理是在本地搭建了一个express服务器。

但是在服务器上就不是这样的,必须要通npm run build命令来对整个项目进行打包,打包后会在项目目录下生成一个dist文件夹,内容如下:

f809d90bbb3d8f9974793637af054d8a.png

然后就是把这些文件丢到服务器上的某个文件夹下,我这里的文件夹名字是ibms

fc68bc9842f3197b5f83e8721fe8ec8e.png

遇到的问题:

1. 直接去访问http://www.xxx.com/ibms/,会发现网页是白屏的,什么都没有,这就比较奇怪了,其实是因为资源加载的路径有问题!

解决方法:

在config中的index.js里build下修改webpack配置:

assetsPublicPath: "/ibms/"

在router中的index.js配置中加上:

export default new Router({

mode: "history",

scrollBehavior: () => ({ y: 0 }),

base: "/ibms/", // 加上这一行

routes: constantRouterMap

})

接下来再重新npm run build打包,然后丢到服务器上ibms文件夹下,这时页面就可以正常访问了。

2. 在当前页面刷新或者用url栏访问某个子页面,结果发现网页404了,这是因为vue路由的mode是history模式。

解决方法:

把所有的请求全部转发到http://www.xxx.com/ibms/index.html上就可以了

我这里用的是apache做的web服务器,在ibms目录下新建.htaccess文件(跟index.html同级),编辑代码。

27bdff4c5c1d34800c3a7c6e43b32eae.png

RewriteEngine On

RewriteBase /ibms/

RewriteRule ^index.html$ - [L]

RewriteCond %{REQUEST_FILENAME} !-f

RewriteCond %{REQUEST_FILENAME} !-d

RewriteRule . /ibms/index.html [L]

这个配置的作用就是把所有服务器上不存在请求全部转发到index.html上去。(PS:记得要重启apache服务器哦)

到此这篇关于Vue项目打包部署到apache服务器的方法步骤的文章就介绍到这了,更多相关Vue项目打包部署到apache内容请搜索云海天教程以前的文章或继续浏览下面的相关文章希望大家以后多多支持云海天教程!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/619334
推荐阅读
相关标签
  

闽ICP备14008679号