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

简介: 为什么 SAP UI5 应用初始化时,要调用 SAP UI5 设备检测 API,即 sap.ui.Device 来检测运行当前 SAP UI5 应用的设备类型?

为什么 SAP UI5 应用初始化时,要调用 SAP UI5 设备检测 API,即 sap.ui.Device 来检测运行当前 SAP UI5 应用的设备类型?


可以查看我这篇文章:SAP UI5 应用开发教程之三十四 - SAP UI5 应用基于设备类型的页面适配功能(Device Adaptation)。


本文介绍该设备检测 API 本身的工作原理。


Device API 所在的 Device.js 文件被加载后,立即执行 setOS 方法:

59.png

OS 结构变量可以看出,SAP UI5 支持下列几种操作系统的检测:

  • Android
  • iOS
  • Linux
  • mac
  • Windows

1.png

我们通过浏览器的 userAgent 来判断操作系统类型:Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, likeGecko) Chrome/97.0.4692.99 Safari/537.36

image.png

使用正则表达式匹配,如果发现有 Android 字符串,则说明当前的 SAP UI5 应用,运行在 Android 移动设备上。

image.png

如果没有检测到,进入 getDesktopOS 分支。

我用的是 Windows10 操作系统,platform 字段值为 Win32:

2.png

成功解析出操作系统的版本号为 10:

5.png

给 Device API 里的 device 对象设置对应的 os 值:

6.png

image.png

然后执行 setBrowser 设置浏览器对应的 flag:

image.png

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

var rwebkit = /(webkit)[ \/]([\w.]+)/;
var rmozilla = /(mozilla)(?:.*? rv:([\w.]+))?/;

image.png

image.png

最后仍然通过正则表达式结合 userAgent,检测出我在 Windows10 操作系统上使用的浏览器类型为 Chrome

image.png

根据这个 StackOverflow 帖子 提到的如何检测 Chrome 是否使用了 blink 渲染引擎的实现:

7.png

给 Device 全局变量的 support 字段赋值:

image.png

进入设备类型检测:

9.png首先检测是否是 tablet

var bTabletDetected = !!isTablet(customUA);

从这里能够看出,SAP UI5 判断一个设备是 tablet 的逻辑为,如果该设备的操作系统是 windows 或者 mac 或者 Linux,那么如果它支持 touch 操作,就被看成是 tablet

image.png

从下图代码,我们终于找到了 SAP UI5 判定当前 device 是 phone 的逻辑:如果设备支持 touch 操作并且不是 tablet,那么一定是 phone.

10.png

而检测一台设备是否支持 touch 的逻辑:

11.png

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



目录
相关文章
|
28天前
|
安全 前端开发 物联网
现代 API 的类型划分
【2月更文挑战第28天】
|
1月前
|
XML 前端开发 JavaScript
深入介绍 UI5 框架里 Smart Field 控件的工作原理
深入介绍 UI5 框架里 Smart Field 控件的工作原理
16 0
|
2月前
|
小程序 安全 API
社区每周丨小程序基础API新增获取设备、系统等多个接口
社区每周丨小程序基础API新增获取设备、系统等多个接口
106 0
|
9天前
|
Java BI API
SAP Cloud for Customer 里如何通过 ABSL 二次开发方式消费 SAP S/4HANA 系统的 API
SAP Cloud for Customer 里如何通过 ABSL 二次开发方式消费 SAP S/4HANA 系统的 API
12 0
|
1月前
|
编解码 API Android开发
深入了解设备交互 API 如何改变我们的生活
深入了解设备交互 API 如何改变我们的生活
29 3
|
6月前
|
安全 网络安全 API
SAP ABAP 通过 https 消费外部 API 遇到错误消息 SSSLERR_SSL_CONNECT
SAP ABAP 通过 https 消费外部 API 遇到错误消息 SSSLERR_SSL_CONNECT
116 0
|
2月前
|
XML JavaScript 数据格式
SAP UI5 XML Preprocessor 的工作原理和 instructions 指令详解
SAP UI5 XML Preprocessor 的工作原理和 instructions 指令详解
28 0
|
2月前
|
前端开发
问题解答:SAP UI5 应用设置禁止被其他应用嵌入运行的工作原理解析试读版
问题解答:SAP UI5 应用设置禁止被其他应用嵌入运行的工作原理解析试读版
113 0
|
3月前
|
XML API 网络架构
API的类型及其区别是什么?
API的类型及其区别是什么?
|
3月前
|
JSON 关系型数据库 MySQL
这个问题是由于Flink的Table API在处理MySQL数据时,将MULTISET类型的字段转换为了JSON格式
【1月更文挑战第17天】【1月更文挑战第84篇】这个问题是由于Flink的Table API在处理MySQL数据时,将MULTISET类型的字段转换为了JSON格式
33 1