共计 2857 个字符,预计需要花费 8 分钟才能阅读完成。
在做移动端时,想起用 navigator.userAgent 来对浏览器类型进行判断,查了点资料,在这里总结下还有一个就是移动端的缩放问题,在 meta 标签中进行设置,对部分浏览器进行强制性的限制
1.navigator 的一些常用属性
navigator 为 window 对象的一个属性,指向了一个包含浏览器相关信息的对象
navigator.appVersion 浏览器的版本号
navigator.language 浏览器使用的语言
navigator.userAgent 浏览器的 userAgent 信息
其中 userAgent 属性是一个只读的字符串,声明了浏览器用于 HTTP 请求的用户代理头的值。
2. 较常见的 ios 端、Android 端及 PC 端的判断
简单点的
/* 判断浏览器类型 */
let userAgent = navigator.userAgent;
/* 判断手机型号 */
let app = navigator.appVersion;
/* Android 终端 */
let isAndroid = userAgent.indexOf(‘Android’);
/* ios 终端 */
let isMac = !!userAgent.match(/\(i[^;]+;(U;)? CPU.+Mac OS X/);
封装性的
/* 判断各类型方法 */
const browser = {
version: function() {
const userAgent = navigator.userAgent;
return {
/* 判断是否是 ios */
ios: !!userAgent.match(/\(i[^;]+;(U;)? CPU.+Mac OS X/),
/* 判断是否是 Android */
android: userAgent.indexOf(‘Android’) > -1 || userAgent.indexOf(‘Adr’) > -1,
/* 判断是否是移动端 */
mobilePhone: !!userAgent.match(/AppleWebKit.*Mobile.*/),
/* IE 内核 */
trident: userAgent.indexOf(‘Trident’) > -1,
/* opera 内核 */
presto: userAgent.indexOf(‘Presto’) > -1,
/* 苹果、谷歌内核 */
webkit: userAgent.indexOf(‘AppleWebKit’) > -1,
/* 火狐内核 */
gecko: userAgent.indexOf(‘Gecko’) > -1 && userAgent.indexOf(‘KHTML’) == -1,
/* 判断是否是 IPone 手机或者 QQHD 浏览器 */
iphone: userAgent.indexOf(‘iPhone’) > -1,
/* 判断是否是 iPad */
iPad: userAgent.indexOf(‘iPad’) > -1,
/* 判断是否是 web 应用程序 (能够让用户完成某些特定任务的网站),没有头部和底部 */
webApp: userAgent.indexOf(‘Safari’),
/* 是否是微信 */
weixin: userAgent.indexOf(‘MicroMessenger’),
/* QQ */
QQ: userAgent.match(/\sQQ/i) == ‘ qq’,
}
}(),
/* 判断浏览器使用的语言:navigator.language 除 IE 浏览器外的浏览器使用的语言,
* navigator.browserLanguageIE 浏览器使用的语言
*/
browserLanguage: (navigator.language || navigator.browserLanguage).toLowerCase()
};
if(browser.version.ios || browser.version.android || browser.version.mobilePhone) {
console.log(‘ 是移动端 ’);
}
3.meta 标签设置
如对浏览器进行强制全屏的设置(UC 全屏),webapp 模式等
<meta charset=”UTF-8″>
<!– 视图窗口,移动端特属的标签 –>
<meta name=”viewport” content=”width=device-width,initial-scale=1,maximum-scale=1,minimum-scale=1,user-scalable=no”>
<!– 避免 IE 使用兼容模式 –>
<meta http-equiv=”x-ua-compatible” content=”IE=edge”>
<!– uc 强制竖屏 –>
<meta name=”screen-orientation” content=”portrait”>
<!– QQ 强制竖屏 –>
<meta name=”x5-orientation” content=”portrait”>
<!– UC 强制全屏 –>
<meta name=”full-screen” content=”yes”>
<!– QQ 强制全屏 –>
<meta name=”x5-fullscreen” content=”true”>
<!– UC 应用模式 –>
<meta name=”browsermode” content=”application”>
<!– QQ 应用模式 –>
<meta name=”x5-page-mode” content=”app”>
<!– 是否启动 webapp 功能,会删除默认的苹果工具栏和菜单栏 –>
<meta name=”apple-mobile-web-app-capable” content=”yes”>
<!– 这个主要是根据实际的页面设计的主体色为搭配来进行设置 –>
<meta name=”apple-mobile-web-app-status-bar-style” content=”black”>
<!– 忽略页面中的数字识别为电话号码,email 识别 –>
<meta name=”format-decoration” content=”telephone=no,email=no”>
<!– 启用 360 浏览器的极速模式 (webkit) –>
<meta name=”renderer” content=”webkit”>
<!– 针对手持设备优化,主要是针对一些老的不识别 viewport 的浏览器,比如黑莓 –>
<meta name=”HandheldFriendly” content=”true”>
<!– 微软的老式浏览器 –>
<meta name=”MobileOptimized” content=”320″>
<!– windows phone 点击无高光 –>
<meta name=”msapplication-tap-highlight” content=”no”>
正在努力学习中,若对你的学习有帮助,留下你的印记呗(点个赞咯 ^_^)
往期好文推荐:
webpack 打包(有面试题)
纯 css 实现瀑布流(multi-column 多列及 flex 布局)
画三角形