正在苦逼的实习中,昨天公司让做一个页面,涉及到检测终端的问题,如果是手机设备,就跳转到指定的网页上,以前写响应式布局只要用@media screen
来实现布局的差异化适应,但是现在不仅仅是布局,还要针对移动端做一些别的动作,所以看了点资料,做个总结
还是用@media screen
思路:css使用媒体查询,当屏幕小于760px时,使某个元素的样式发生改变,然后通过js检测到这个改变,就可以知道现在切换到移动端了
css代码:
1 | /* 检测小屏幕- */ |
js代码:
1 | $( document ).ready(function() { |
通过navigator.userAgent字符串检测
思路:Navigator
对象包含有关浏览器的信息,通过检测userAgent
字符串,然后使用正则表达式进行匹配,我们自然就能知道用户是否在使用移动端的浏览器啦
先上个简化版的,意思意思下:
1 | var isMobile = false; |
其实还可以用jQuery,但是jQuery从1.9版开始,移除了$.browser
和$.browser.version
:
1 | $.browser.device = (/android|webos|iphone|ipad|ipod|blackberry|iemobile|opera mini/i.test(navigator.userAgent.toLowerCase(); |
通过上面那段代码基本就能检测到我们能常用的移动终端了,但是后来我在stackoverflow发现一哥们检测得更加全面牛逼:
1 | var isMobile = false;//默认PC端 |
通过Window.matchMedia()检测
思路:Window.matchMedia()
用来检查mediaquery语句,。它返回一个MediaQueryList
对象。该对象有两个属性
media:查询语句的内容。
matches:如果查询结果为真,值为true,否则为false
1 | var isMobile = false;//默认PC端 |
如果在PC端上使用Window.matchMedia()
的话IE10以下是不支持的,但是我们只是用来检测终端哈,IE不支持就算了,移动端上安卓3.0以上都没有问题,so~~
检测移动端的TouchEvent事件
思路:使用document.createEvent()
创建TouchEvent事件,如果成功那就是移动端了,返回true,pc端是没有TouchEvent事件的,所以会出错,返回false
1 | var isMobile = false;//默认PC端 |
使用Device.js库
这个库就没啥好讲的了,自己跟着套代码就OK
github地址 https://github.com/matthewhudson/device.js
不想看英文的孩子,扔个中文教程 https://segmentfault.com/a/1190000000373735