SAP Cloud for Customer里一个Promise的实际应用场合

简介: There are lots of tutorials about promise in the internet.Recently I am studying the frontend code of SAP Cloud for Customer and I come across a real example of how promise is used there.Below is the Passcode logon view.

image.png

image.png

<!doctype html>
<html>
<head>
<script>
var end;
function setupDB(){
  return this.createDatabase().then(createTable).then(insertEntry).then(readEntry).then(printResult);
}
function createTable(){
  return new Promise(function(resovle, reject) {
    console.log("prepare to create table..." + Date.now());
    this._db.transaction(function(query){
      query.executeSql('create table if not exists user(id unique, user, passwd)');
    });
    setTimeout( _createTableOK.bind(this, resovle), 1000);
  });
}
function _createTableOK(resovle){
  console.log("table created successfully..." + Date.now());
  resovle();
}
function createDatabase(){
  return new Promise(function(resovle, reject) {
    console.log("prepare to create database..." + Date.now());
    this._db = openDatabase('mydb','1.0', 'JerryTestdb',1024);
    setTimeout( _createDatabaseOK.bind(this, resovle), 1000);
  });
}
function _createDatabaseOK(resovle){
  console.log("database created successfully..." + Date.now());
  resovle(this._db);
}
function insertEntry(){
  return new Promise(function(resolve, reject) {
    this._db.transaction(function(query){
      query.executeSql("insert into user values (1,'Jerry','1234')");
    });
    setTimeout( _insertEntryOK.bind(this, resolve), 1000);
  });
}
function _insertEntryOK(resolve){
  console.log("entry inserted to table successfully..." + Date.now()); 
  resolve();
}
function readEntry() {
  return new Promise(function(resolve, reject) {
      this._db.transaction( function(query) {
        query.executeSql('select * from user',[],function(u,results) {
        setTimeout( _readEntryOK.bind(this, resolve, results), 1000);
      }); // end of query.executeSql
   } // end of function(query)
   ); // end of this._db.transaction
 });
}
function _readEntryOK(resolve, oResult){
  console.log("entry readed from DB successfully..." + Date.now());
  resolve(oResult);
}
function printResult(oResults){
  for( var i = 0; i < oResults.rows.length; i++) {
      document.writeln('id: ' + oResults.rows[i].id);
      document.writeln('user: ' + oResults.rows[i].user);
      document.writeln('passwd: ' + oResults.rows[i].passwd);
  }
  end = true;
}
function work(){
  if( end ){
    clearInterval(handle);
  }
  else{
    console.log(" working..." + Date.now());
  }
}
setupDB();
var handle = setInterval( work, 200);
</script>
</head>
</html>

image.png

image.png

image.png

相关文章
|
2月前
|
Web App开发 数据采集 前端开发
纯技术讨论:如何让 SAP UI5 应用无法被别人在浏览器里调试 - 这种做法不推荐试读版
纯技术讨论:如何让 SAP UI5 应用无法被别人在浏览器里调试 - 这种做法不推荐试读版
20 0
|
2月前
|
XML 存储 数据格式
SAP UI5 控件 customData 属性的应用介绍
SAP UI5 控件 customData 属性的应用介绍
35 0
|
3月前
|
Web App开发 前端开发 JavaScript
乱花渐欲迷人眼 - 让 SAP UI5 应用的日志输出不再素面朝天
乱花渐欲迷人眼 - 让 SAP UI5 应用的日志输出不再素面朝天
51 0
|
3月前
SAP UI5 应用如何实现类似百度首页一样的访问方式试读版
SAP UI5 应用如何实现类似百度首页一样的访问方式试读版
35 0
|
3月前
让 SAP UI5 应用的日志打印变得五彩缤纷试读版
让 SAP UI5 应用的日志打印变得五彩缤纷试读版
99 2
|
15天前
|
前端开发 NoSQL Serverless
Serverless 应用引擎操作报错合集之阿里函数计算中,出现"Unhandled promise rejection"的错误如何解决
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
19 1
|
1月前
|
安全 UED 开发者
SAP Commerce Cloud 配置项 refreshWithLock=false 的作用介绍
SAP Commerce Cloud 配置项 refreshWithLock=false 的作用介绍
22 0
|
1月前
关于 SAP ABAP OData 服务如何实现 Deep Insert 场景 - SAP 应用的标准行为试读版
关于 SAP ABAP OData 服务如何实现 Deep Insert 场景 - SAP 应用的标准行为试读版
16 1
|
1月前
|
Java BI API
SAP Cloud for Customer 里如何通过 ABSL 二次开发方式消费 SAP S/4HANA 系统的 API
SAP Cloud for Customer 里如何通过 ABSL 二次开发方式消费 SAP S/4HANA 系统的 API
21 0
|
3月前
|
前端开发 JavaScript
JavaScript中的异步编程及Promise的应用
在前端开发中,异步编程是常见的需求,而Promise作为一种解决异步操作的技术,具有很高的应用价值。本文将介绍JavaScript中的异步编程原理,并结合实际案例详细讲解Promise的使用方法及其在前端开发中的应用。
14 2