@H_502_0@vue-router 默认是hash模式,使用url的hash来模拟一个完整的url,当url改变的时候,页面不会重新加载。但是如果我们不想hash这种以#号结尾的路径时候的话,我们可以使用路由的history的模式。比如如下网址:
@H_502_0@使用hash模式的话,那么访问变成 <a rel="external nofollow" href="http://localhost:8080/bank/page/count/#/">http://localhost:8080/bank/page/count/#/ 这样的访问,如果路由使用 history的话,那么访问的路径变成 如下: @H_502_0@在路由的配置就是如下:我们还是以 vue-cli项目为例: @H_502_0@在src/router/index.js 代码如下:
一: apache服务器上的配置如下:
1. 如果我们现在是使用apache做web服务器的话,我们需要开启 .htaccess支持即可:
在文件里加上如下,就一切正常了
上面的apache的作用是:把所有服务器上不存在的请求全部转发到 index.html上去,这样就可以直接通过各种url来访问了。
注意:
1. RewriteRule . /bank/page/index.html [L] 这段代码;前面需要加 /bank/page/这样的,因为我在路由配置base里面
加了 /bank/page/ 这个路径,否则匹配不到了。
2. vue-cli 项目中需要修改 config/index.js 中的build下的 assetsPublicPath: '/bank/page/',如果使用相对路径,
chunk文件会报错找不到。
3. 在apache的 www/bank/page 目录下新建 .htaccess文件,需要修改RewriteRule 为/bank/page/index.html,否则刷新页面服务端会直接报404错误。
4. 修改httpd.conf文件,开启rewrite_module功能。
5. LoadModule rewrite_module libexec/apache2/mod_rewrite.so,去掉前面的#
6. 然后找到AllowOverride None的那行,把它改成AllowOverride All,来使.htaccess文件生效。
二:nginx服务器上的配置如下:
vue-cli 执行打包命令:
如上进行打包,生成dist文件夹,把该文件夹下的文件直接复制到nginx服务器目录下,就可打开项目,但是只有首页可以看到的,刷新一下页面也是404了,原因和上面一样,因此需要在nginx服务器配置对所有的路径或者文件夹进行跳转,重定向到首页 index.html即可:这样就能找到路由了。
nginx服务器配置如下:
1. 首先登录服务器。
2. 进入目录 /etc/usr/local/nginx/conf/下;
执行命令:
2-1 cd /etc/ 回车
2-2 cd /usr/ 回车
2-3 cd loacl/ 回车
2-4 cd nginx 回车
2-5 cd conf 回车
2-6 vi nginx_v4.conf 进入 nginx文件内 新建一个项目的相关配置如下:
比如我们现在的域名地址这样访问的:,需要如下配置:
try_files 指令:
@H_502_0@语法:try_files file ... uri 或 try_files file ... = code @H_502_0@默认值:无 @H_502_0@作用域:server location @H_502_0@其作用是按顺序检查文件是否存在,返回第一个找到的文件或文件夹(结尾加斜线表示为文件夹),如果所有的文件或文件夹都找不到,会进行一个内部重定向到最后一个参数。 @H_502_0@需要注意的是,只有最后一个参数可以引起一个内部重定向,之前的参数只设置内部URI的指向。最后一个参数是回退URI且必须存在,否则会出现内部500错误。命名的location也可以使用在最后一个参数中。与rewrite指令不同,如果回退URI不是命名的location那么 @H_502_0@args不会自动保留,如果你想保留args,则必须明确声明。 @H_502_0@location指令
@H_502_0@语法:location [=|~|~*|^~|@] /uri/ { … } @H_502_0@默认值:无 @H_502_0@作用域:server @H_502_0@location指令是用来为匹配的URI进行配置,URI即语法中的"/uri/",可以是字符串或正则表达式。但如果要使用正则表达式,则必须指定前缀。 [@] 即是命名location,一般只用于内部重定向请求。 @H_502_0@3. 设置成功后需要重启:Nginx重启命令;在 /etc/usr/local/Nginx/conf/ 目录下,cd ../ 然后进入sbin目录下 cd sbin 接着运行命令 ./Nginx -s reload 重启后即可生效。 @H_502_0@4. 在/data/www/logs/Nginx/aa/目录下 新建 access.log 文件。 @H_502_0@然后Nginx保存和退出命令 :wq @H_502_0@直接退出的命令是 :q @H_502_0@5. mac系统下 自带 apache2服务器,需要对apache2作反向代理;配置如下: @H_502_0@进入本地mac apache2配置; @H_502_0@命令:cd /etc/apache2 @H_502_0@命令:sudo vi httpd.confsudo apachectl restart
@H_502_0@6. java服务端的配置如下 (如果是vm放到开发那边的话,开发那边需要如下处理下,如果页面vm不放在开发那边的话,下面的配置可以忽略)
@H_502_0@在项目目录下 webapp/web-inf/view/ 新建文件夹 aa 和 include文件
@H_502_0@aa文件下 新建index.vm
@H_502_0@如下代码: