当前位置:主页 > seo优化知识 > 【优化知识】怎样判断搜索页面是由移动端还是pc端打开的

【优化知识】怎样判断搜索页面是由移动端还是pc端打开的

2019-05-06 09:10 发布: 寅森508来源: 未知 浏览:

   怎样判断搜索页面是由移动端还是pc端打开的



      1、简单的利用JS来判断页面是在手机端还是在PC端打开的方法

  Navigator对象

  首先来了解一下Navigator 对象,Navigator 对象包含有关浏览器的信息,下面的userAgent 属性是一个只读的字符串,声明了浏览器用于 HTTP 请求的用户代理头的值。所以我们可以通过判断navigator.useragent里面是否有某些值来判断,比如我的电脑是mac,所以打印出来的值为

  Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36

  具体含义不解释,有兴趣同学自行百度,可以看到里面含有 Mac 字样,其他的也是类似的。

  那如何判断页面是在移动端还是PC端打开的呢?

  网上有很多方法,写的或难或简单,实际上一行代码就够了

  window.location.href = /Android|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent) ? "https://www.baidu.com/" : "http://news.baidu.com/";

  以上代码利用了正则表达式和三目运算符,含义就是如果是移动端打开的话那就跳转到 "https:www.baidu.com/" ,如果不是就跳转到"http://new.baidu.com/",这个看不懂的话,那我下面这样写就很容易理解了吧

  if(/Android|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent)) {

  window.location.href = "https://www.baidu.com/";

  } else {

  window.location.href = "http://news.baidu.com/";

  }

  什么?if里面的判断还是看不懂?实际上就是利用正则去判断 navigator.useragent 是否含有 Android/webOs/iphone 等字符串,并且利用修饰符 "i" 做了不区分大小写,然后用正则的方法 test 去判断是否满足,如果这种方式不理解的话完全可以利用字符串的 indexOf 方法去判断。

  2、css如何判断页面是由移动端打开还是pc端

  在做Web前端开发中,经常要考虑到pc端和移动端对功能的不同需求,这时候通常需要根据设备的不同做到一定的响应,这时候可以通过媒体查询实现不同设备宽度下的不同样式,也可以通过判断访问设备的类型,通过判断的结果,返回不同的域名地址,继而加载不同的CSS文件。

  那么如何判断页面是由移动端还是PC端打开呢,也就是说怎么判断访问设备的类型呢?

  1.媒体查询,但是这个只能判断尺寸,并不能判断是不是移动设备。

  2.通过user-agent值,来进行判断。使用javascript框架中的Navigator对象的userAgent属性。

  function IsPC() {

  var userAgentInfo = navigator.userAgent;

  var Agents = ["Android", "iPhone","SymbianOS", "Windows Phone", "iPod"];

  var flag = true;

  for (var v = 0; v < Agents.length; v++) {

  if (userAgentInfo.indexOf(Agents[v]) > 0) {

  flag = false;

  break;

  }

  }

  if(window.screen.width>=768){

  flag = true;

  }

  return flag;

  }

  通过以上代码就可以判断出访问网站的设备类型到底是PC端还是移动端。

90%的人会对以下内容感兴趣:

.......................