51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

前端开发:如何实现“移动设备访问PC域名的时候跳转到移动网站”的应用

近期一直忙于一个业务的PC和移动html5版本的改版,折腾了很久,累得够呛,今天终于完美交工。每次项目完成后,都想分享点内容,本次想谈下很小的知识点:移动设备访问PC域名的时候跳转到移动网站。

这个功能相信大家都比较熟悉了,或许也做过,但是今天介绍一系列方法,供大家参考。首先看下PC和移动的效果图:

PC

mobile

接下来介绍一种简单的方法,分析下如何实现的。

第一步

我们首先需要熟悉移动端的设备参数有哪些,废话不多说,直接列举下吧:

phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone

了解后,我们就可以对于这些参数去判断了。

第二步

通过JS的if语句去判断,上代码:

if ((navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i))) {
      window.location.href="/mobile/";
      console.log("mobile");
      return false;
  }
  else {
      window.location.href="/";
      console.log("pc");      
      return false;
  }

第三步

一般像这种公用的组件代码,我们需要封装起来,比如利用函数goToPage(),然后再去调用,这样会好很多,方便其他同事去应用。

// 识别设备
function goToPage() {
  if ((navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i))) {
      window.location.href="/mobile/";
      console.log("mobile");
      return false;
  }
  else {
      window.location.href="/";
      console.log("pc");      
      return false;
  }
}

以上代码,我们可以根据自己具体的项目,去指定window.location.href的路径,看上去是不是很简单呢。

但是。。。。。。。。问题来了,移动打开PC正常可以跳转到html5页面的,但是PC打开PC地址,就不停的跳转reload,这肯定不行的啊,所以我们可以用最简单的方法去处理,通过单方面的判断,也就是去掉else,代码如下:

// 识别设备
function goToPage() {
  if ((navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i))) {
      window.location.href="/mobile/";
      console.log("mobile");
      return false;
  }
}

OK,这样就正常了。

上面介绍的只是其中一种方法,我还收集了一些其他方法,供大家学习下,直接列举吧。

其他方法

至于以下的方法,就不一一再去分析了,大家有疑问可以留言咨询,或者加QQ群讨论。

方法二

function IsPC() {
    var userAgentInfo = navigator.userAgent;
    var Agents = ["Android", "iPhone",
                "SymbianOS", "Windows Phone",
                "iPad", "iPod"];
    var flag = true;
    for (var v = 0; v < Agents.length; v++) {
        if (userAgentInfo.indexOf(Agents[v]) > 0) {
            flag = false;
            break;
        }
    }
    return flag;
}

方法三

function browserRedirect() {
    var sUserAgent = navigator.userAgent.toLowerCase();
    var bIsIpad = sUserAgent.match(/ipad/i) == "ipad";
    var bIsIphoneOs = sUserAgent.match(/iphone os/i) == "iphone os";
    var bIsMidp = sUserAgent.match(/midp/i) == "midp";
    var bIsUc7 = sUserAgent.match(/rv:1.2.3.4/i) == "rv:1.2.3.4";
    var bIsUc = sUserAgent.match(/ucweb/i) == "ucweb";
    var bIsAndroid = sUserAgent.match(/android/i) == "android";
    var bIsCE = sUserAgent.match(/windows ce/i) == "windows ce";
    var bIsWM = sUserAgent.match(/windows mobile/i) == "windows mobile";
    if (!(bIsIpad || bIsIphoneOs || bIsMidp || bIsUc7 || bIsUc || bIsAndroid || bIsCE || bIsWM) ){
        window.location.href=B页面;
    }
}
browserRedirect();

方法四(百度方法)

function uaredirect(f) {
 try {
  if (document.getElementById("bdmark") != null) {
   return
  }
  var b = false;
  if (arguments[1]) {
   var e = window.location.host;
   var a = window.location.href;
   if (isSubdomain(arguments[1], e) == 1) {
    f = f + "/#m/" + a;
    b = true
   } else {
    if (isSubdomain(arguments[1], e) == 2) {
     f = f + "/#m/" + a;
     b = true
    } else {
     f = a;
     b = false
    }
   }
  } else {
   b = true
  }
  if (b) {
   var c = window.location.hash;
   if (!c.match("fromapp")) {
    if ((navigator.userAgent.match(/(iPhone|iPod|Android|ios|SymbianOS)/i))) {
     location.replace(f)
    }
   }
  }
 } catch(d) {}
}
function isSubdomain(c, d) {
 this.getdomain = function(f) {
  var e = f.indexOf("://");
  if (e > 0) {
   var h = f.substr(e + 3)
  } else {
   var h = f
  }
  var g = /^www\./;
  if (g.test(h)) {
   h = h.substr(4)
  }
  return h
 };
 if (c == d) {
  return 1
 } else {
  var c = this.getdomain(c);
  var b = this.getdomain(d);
  if (c == b) {
   return 1
  } else {
   c = c.replace(".", "\\.");
   var a = new RegExp("\\." + c + "$");
   if (b.match(a)) {
    return 2
   } else {
    return 0
   }
  }
 }
};

OK,一共四种方法,就这么多了,大家拿去用吧。

总结

Web前端开发中,一个小小的知识点,就可以引发这么多的方法,可想而知,我们需要学习的东西还有很多,加油吧,老铁们!

赞(3)
未经允许不得转载:工具盒子 » 前端开发:如何实现“移动设备访问PC域名的时候跳转到移动网站”的应用