落花踏尽游何处,笑入胡姬酒肆中。这篇文章主要讲述SAP UI5 设备类型检测 Device API 的工作原理相关的知识,希望能为你提供帮助。
为什么 SAP UI5 应用初始化时,要调用 SAP UI5 设备检测 API,即 sap.ui.Device
来检测运行当前 SAP UI5 应用的设备类型?
可以查看我这篇文章:SAP UI5 应用开发教程之三十四 - SAP UI5 应用基于设备类型的页面适配功能(Device Adaptation)。
本文介绍该设备检测 API 本身的工作原理。
Device API 所在的 Device.js 文件被加载后,立即执行 setOS
方法:
文章图片
从
OS
结构变量可以看出,SAP UI5 支持下列几种操作系统的检测:- android
- ios
- Linux
- mac
- Windows
文章图片
我们通过浏览器的
userAgent
来判断操作系统类型:Mozilla/5.0 (Windows NT 10.0;
Win64;
x64) AppleWebKit/537.36 (Khtml, like Gecko) Chrome/97.0.4692.99 Safari/537.36文章图片
使用正则表达式匹配,如果发现有 Android 字符串,则说明当前的 SAP UI5 应用,运行在 Android 移动设备上。
文章图片
如果没有检测到,进入
getDesktopOS
分支。我用的是 Windows10 操作系统,platform 字段值为
Win32
:文章图片
成功解析出操作系统的版本号为 10:
文章图片
给 Device API 里的 device 对象设置对应的 os 值:
文章图片
文章图片
然后执行
setBrowser
设置浏览器对应的 flag:文章图片
基于
webkit
和 mozilla
的浏览器类型检测,使用下面的正则表达式完成:var rwebkit = /(webkit)[ \\/]([\\w.]+)/;
var rmozilla = /(mozilla)(?:.*? rv:([\\w.]+))?/;
文章图片
文章图片
最后仍然通过正则表达式结合
userAgent
,检测出我在 Windows10 操作系统上使用的浏览器类型为 Chrome
:文章图片
根据这个 StackOverflow 帖子 提到的如何检测 Chrome 是否使用了
blink
渲染引擎的实现:文章图片
给 Device 全局变量的 support 字段赋值:
文章图片
进入设备类型检测:
文章图片
首先检测是否是
tablet
:var bTabletDetected = !!isTablet(customUA);
从这里能够看出,SAP UI5 判断一个设备是
tablet
的逻辑为,如果该设备的操作系统是 windows 或者 mac 或者 Linux,那么如果它支持 touch
操作,就被看成是 tablet
:文章图片
从下图代码,我们终于找到了 SAP UI5 判定当前 device 是
phone
的逻辑:如果设备支持 touch
操作并且不是 tablet
,那么一定是 phone
.文章图片
而检测一台设备是否支持 touch 的逻辑:
【SAP UI5 设备类型检测 Device API 的工作原理】
文章图片
var detectTouch = function ()
return !!((ontouchstart in window)
|| (window.navigator.maxTouchPoints >
0)
|| (window.DocumentTouch &
&
document instanceof window.DocumentTouch)
|| (window.TouchEvent &
&
Device.browser.firefox));
;
推荐阅读
- Nessus 主机漏洞扫描器安装配置使用
- HarmonyOS - 方舟开发框架ArkUI 基于JSAPI实现五子棋游戏
- kubernetes与velero的第一次尝试
- 解决IntelliJ idea的Maven Cannot resolve XXX PluginsDependencis等爆红问题总结
- Python 地图篇 - 使用pyecharts绘制世界地图中国地图省级地图市级地图实例详解
- 代码实现nadaraya-waston核回归#51CTO博主之星评选#
- Bash 特性
- Docker 安装部署
- Windows 窗口样式 什么是 WS_EX_NOREDIRECTIONBITMAP 样式