vue项目打包后想发布在apache www/vue 目录下

使用的是vue-element-admin 作示例,其余项目应该大同小异。html

使用vue-router的browserHistory模式,配置mode: 'history', 有更好的体验。vue

目的: 想将项目打包后发布到apache的www下的vue子目录

先讲结论:

  1. 须要修改router/index.jsnew Router 配置,加一个base: '/vue/', 它指定应用的基路径,该应用是服务于localhost/vue路径下,因此必须加base配置,不然应用会展现404页面
  2. 须要修改config/index.js中build下的assetsPublicPath: '/vue/',若是用相对路径,chunk文件会报错找不到。
  3. 修改httpd.conf文件,开启rewrite_module功能。git

    • LoadModule rewrite_module libexec/apache2/mod_rewrite.so,去掉前面的#。
    • 而后找到 AllowOverride None的那行,把它改为AllowOverride All,来使.htaccess文件生效。
  4. 在apache 的www/vue 目录下新建.htaccess文件, 须要修改RewriteRule/vue/index.html, 不然刷新页面服务端会直接报404错误。

.htaccess文件内容

<IfModule mod_rewrite.c>
  RewriteEngine On
  RewriteBase /
  RewriteRule ^index\.html$ - [L]
  RewriteCond %{REQUEST_FILENAME} !-f
  RewriteCond %{REQUEST_FILENAME} !-d
  RewriteRule . /vue/index.html [L]
</IfModule>

放到www根目录,或更深的目录,只须要对应的修改便可。第一点比较重要,参考项目的文档上也没有说明,加上不够细致,对新手仍是有门槛的。 github

但愿这篇文档帮助更多人。。。vue-router

相关文章
相关标签/搜索