javascript - uc、qq、搜狗 以上三个手机浏览器判断移动端的js代码不执行
问题描述
如题写了一段代码判断移动端就跳转,但是在uc、qq、搜狗的手机端不执行,chrome、小米、微信的手机端浏览器可以执行
var browser = {versions: function () { var u = navigator.userAgent, app = navigator.appVersion; return {trident: u.indexOf(’Trident’) > -1, //IE内核presto: u.indexOf(’Presto’) > -1, //opera内核webKit: u.indexOf(’AppleWebKit’) > -1, //苹果、谷歌内核gecko: u.indexOf(’Gecko’) > -1 && u.indexOf(’KHTML’) == -1,//火狐内核mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端ios: !!u.match(/(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端android: u.indexOf(’Android’) > -1 || u.indexOf(’Adr’) > -1, //android终端iPhone: u.indexOf(’iPhone’) > -1, //是否为iPhone或者QQHD浏览器iPad: u.indexOf(’iPad’) > -1, //是否iPadwebApp: u.indexOf(’Safari’) == -1, //是否web应该程序,没有头部与底部weixin: u.indexOf(’MicroMessenger’) > -1, //是否微信 (2015-01-22新增)qq: u.match(/sQQ/i) == ' qq' //是否QQ };}(), }; if (browser.versions.android || browser.versions.ios || browser.versions.mobile || browser.versions.iPhone||browser.versions.webApp||browser.versions.weixin||browser.versions.qq) {window.location = ’mobileWeb.html’ }
问题解答
回答1:if(’ontouchend’ in document) { // 移动端}回答2:
'SE'判断搜狗,'UBrowser'判断UC,要添加两个,修改'QQBrowser'判断QQ,然后试试看
回答3:最终发现了,原来是写了一句es6的语法,uc、搜狗、qq浏览器不支持,导致报错代码不执行。。。下载了一个vConsole调试工具在移动端才显示了错误。
回答4:正则对不上撒。把ua打印出来,自己看下哪里没匹配。移动端的ua不是有更简单的mobile关键字吗?搞的这么复杂?
相关文章:
1. 微信端电子书翻页效果2. python 读取csv文件可以读取但内容错误,但单独用excel打开正常,如何解决?3. css - ul ol前边的标记如何调整样式呢4. php laravel框架模型作用域5. android - 求 360浏览器 百度浏览器 搜狗浏览器的最新启动类名6. javascript - 如何通过参数获取Object的子节点?7. html5 - HTML代码中的文字乱码是怎么回事?8. javascript - 微信小程序 wx.downloadFile下载文件大小有限制吗9. css - 前端flex布局嵌套内层的布局不起作用?10. 安装sublime text 3 控制台的时候出现这个报错怎么办?