SAP UI5 设备类型检测 Device API 的工作原理

Posted JerryWang汪子熙

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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 支持下列几种操作系统的检测:

我们通过浏览器的 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:

基于 webkitmozilla 的浏览器类型检测,使用下面的正则表达式完成:

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 的逻辑:

var detectTouch = function () 
        return !!((ontouchstart in window)
            || (window.navigator.maxTouchPoints > 0)
            || (window.DocumentTouch && document instanceof window.DocumentTouch)
            || (window.TouchEvent && Device.browser.firefox));
    ;

以上是关于SAP UI5 设备类型检测 Device API 的工作原理的主要内容,如果未能解决你的问题,请参考以下文章

SAP UI5 本地开发如何实现 XML 和 JavaScript 代码的自动完成和嵌入式 API 文档自动显示

SAP UI5 navpopover Factory 的使用方法介绍

如何在 SAP UI5 应用中集成第三方库 :一个在移动设备上查看 Web 应用打印调试信息的小技巧

如何在SAP UI5应用里添加使用摄像头拍照的功能

SAP UI5 Responsive Grid Layout 里的 Label-Field Ratio 在屏幕类型 S 下的表现

SAP UI5 web Component里的条件渲染机制