关于 SAP Fiori Elements List Report Go 按钮的实现

简介: 关于 SAP Fiori Elements List Report Go 按钮的实现

代码位置:

这段代码是 JavaScript 中的一个方法 _regularTriggerSearch,它是 SmartFilterBar 对象的原型方法。这个方法的主要目的是在一定延迟后触发搜索操作。这段代码中涵盖了 JavaScript 中的一些主要特性和概念,包括对象、原型、方法、控制流(if-else)、异步编程(setTimeout 和 Promise)等。

首先,我们来分析这个方法的具体内容。这个方法接收一个参数 iDelay,表示延迟的毫秒数。

SmartFilterBar.prototype._regularTriggerSearch = function (iDelay) {
  // ...
}

然后,这个方法首先检查 this.getSuppressSelection() 的返回值。如果返回 true,那么方法就在这里结束返回,不会执行后面的代码。这是一种常见的设计模式,叫做“提前返回”,避免了不必要的嵌套 if-else 结构,使代码更易于阅读和理解。

if (this.getSuppressSelection()) {
  return;
}

接下来,这个方法调用 _clearDelayedSearch() 方法,清理之前可能存在的延迟搜索。然后,使用 setTimeout 方法设置一个延迟操作。setTimeout 是一个全局函数,用于在指定的毫秒数之后执行一段代码。这里,我们延迟执行的是一个函数,如果 iDelay 没有指定,那么这个函数会立即执行。

this._clearDelayedSearch();
this._iDelayedSearchId = setTimeout(function () {
  // ...
}.bind(this), iDelay || 0);

需要注意的是,这里使用了 bind(this) 来确保延迟执行的函数内部的 this 仍然指向 SmartFilterBar 对象。这是因为在 JavaScript 中,函数的 this 是在运行时确定的,它通常指向调用该函数的对象。但是在 setTimeout 中,由于函数是在全局上下文中执行的,所以 this 默认会指向全局对象(在浏览器中是 window)。为了防止这种情况,我们使用 Function.prototype.bind 方法改变 this 的指向。

在这个延迟执行的函数中,首先调用 _getVisibleControlsLoadingPromises() 方法获取一个 Promise 对象的数组。Promise 是 JavaScript 中处理异步操作的一种方式,它代表了一个异步操作的最终结果。这个数组可能为空,也可能包含一个或多个 Promise 对象。

var aPromises = this._getVisibleControlsLoadingPromises();

然后,根据 _bSearchTriggeredOnce 属性和 aPromises 数组的长度来决定如何执行搜索。如果 _bSearchTriggeredOnce 属性为 false,并且 aPromises 数组的长度不为 0(也就是说,有正在加载的控件),那么我们使用 Promise.all 方法等待所有控件加载完成后再执行搜索。Promise.all 方法接收一个 Promise 对象的数组,返回一个新的 Promise 对象

相关文章
|
1月前
SAP UI5 Link 控件的使用方法介绍 - 后续学习 Fiori Elements Smart Link 的基础试读版
SAP UI5 Link 控件的使用方法介绍 - 后续学习 Fiori Elements Smart Link 的基础试读版
15 0
|
1月前
|
UED
什么是 SAP Fiori 的 Technical Catalog 和 Business Catalog
什么是 SAP Fiori 的 Technical Catalog 和 Business Catalog
36 0
|
1月前
|
前端开发 UED
SAP Fiori 到底指什么
SAP Fiori 到底指什么
38 0
|
1月前
|
XML 前端开发 JavaScript
SAP Fiori Launchpad Custom Fields tile 里的 ABAP 语法高亮显示
SAP Fiori Launchpad Custom Fields tile 里的 ABAP 语法高亮显示
14 0
|
2月前
|
XML 存储 JavaScript
关于 SAP Fiori Elements List Report 里的 TableCell.fragment.xml 头部声明
关于 SAP Fiori Elements List Report 里的 TableCell.fragment.xml 头部声明
22 0
|
2月前
SAP Fiori Elements 应用里图片字段(Image)的显示原理介绍试读版
SAP Fiori Elements 应用里图片字段(Image)的显示原理介绍试读版
17 0
|
1月前
|
存储 安全 Java
java集合框架及其特点(List、Set、Queue、Map)
java集合框架及其特点(List、Set、Queue、Map)
|
26天前
|
Java
Java使用List去重的四中方式
Java使用List去重的四中方式
19 6
|
1月前
|
Java
JAVA——List中剔除空元素(null)的三种方法汇总
JAVA——List中剔除空元素(null)的三种方法汇总
|
1月前
|
安全 Java API
Java并发 - J.U.C并发容器类 list、set、queue
Queue API 阻塞是通过 condition 来实现的,可参考 Java 并发 - Lock 接口 ArrayBlockingQueue 阻塞 LinkedBlockingQueue 阻塞 ArrayQueue 非阻塞 LinkedQueue 非阻塞