• 兆隆IT云学院

    招生对象
             年龄再20-30周岁之间,具备大专或同等及以上学历(含大专及以上在读),具备良好的逻辑思维能力,有一定的计算机语言基础,身体健康无残疾,有志再IT行业发展的人士。
    培养目标
       通过对学员专业技术的培训和职业素养的强化训练,使学员具备快速进入软件行业从事专业技术及技术相关工作的能力,并对学员日后

    课程大纲

    师资队伍

    就业展示

  • 兆隆软件培训学院

    招生对象
             年龄在16-22周岁之间,具备高中毕业或同等学历,身体健康无残疾,具有良好的逻辑思维能力,有志IT行业发展人士。
    培养目标
       通过对学员专业基础理论和专业技术的培训和职业素养的强化训练,使学员具备进入软件行业从事专业技术及技术相关工作的能力,并对学员日后职业发展打下必要的知识体系及能力基础

    课程大纲

    师资队伍

    就业展示

js如何判断访问设备并跳转到相应的pc端或移动端?

2018年03月30日 09:01供稿中心:兆隆教育

摘要: 在移动设备应用越来越广泛的今天,许多网站都开始做移动端的界面展示,两者屏幕尺寸差异很大,所以展示的内容也有所差别。所以需要根据来访者设备信息判定跳转的程序,如何用js判断访问设备并跳转到相应的pc端或者移动端呢?
      在移动设备应用越来越广泛的今天,许多网站都开始做移动端的界面展示,两者屏幕尺寸差异很大,所以展示的内容也有所差别。web前端开发初学者需要根据来访者设备信息判定跳转的程序,如何用js判断访问设备并跳转到相应的pc端或者移动端呢?
web移动端开发
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 方法去判断。


文章来源:www.zhaolongedu.com
陕ICP备05010305号 Copyright © 2001-2018隶属于西安兆隆计算机培训学校版权所有