前端使用vue-router做单页面路由并开启history模式时,会碰到一个问题:部分低版本的手机浏览器、部分app以及IE9浏览器由于不支持pushState方法,会导致页面加载不出来。 解决这个问题的思路是:
以下为具体实现方法:
判断使用何种路由模式
let isHans = typeof (history.pushState) === 'function';let mode = isHans?'history':'hash';
判断请求链接
每次进入路由时,判断请求链接跳转的链接与路由模式不匹配时,则跳转至正确的链接
router.beforeEach(async (to, from, next) => {  let toPath = to.fullPath,host = 'http://abc.cn';  let url = host + toPath;  let reUrl = url;  if(isHans && url.indexOf(`${host}/#/`) >-1){    reUrl = url.replace(`${host}/#/`,`${host}/car-insurance/`);  }  if(!isHans && url.indexOf(`${host}/#/`) === -1){    reUrl = url.replace(`${host}/car-insurance/`,`${host}/#/`);    reUrl = reUrl.replace(`${host}/`,`${host}/#/`);  }  if(reUrl !== url){    window.location.replace(reUrl);    return  }配置nginx
server {  listen 80;  listen 443;  server_name abc.cn;  root /data/html;  index index.html index.htm index.json;  access_log off ;  set $isIndex 1;  ##判断IE6-8  if ($http_user_agent ~* "MSIE [6-8].[0-9]") {    rewrite .* /static/ie8.html break;  }  if ( $request_uri ~* "/(favicon.ico|index.js|root.txt|jd_root.txt)$" ) {   #不跳转到index.html    set $isIndex 0;  }  if ( $request_uri ~* "/static/" ) {   #不跳转到index.html    set $isIndex 0;  }  if ($isIndex = 1 ){      set $inIndexJS 0;      rewrite .* /index.html;      break;   }}a以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。
新闻热点
疑难解答