[脚本语言JavaScript]Ringo JS-模块 ringo/promise

RingoJS是一个JavaScript平台,专为服务器端应用设计。它使用Mozilla Rhino引擎执行JavaScript代码,提供了丰富的模块系统,支持CommonJS规范,便于开发复杂的Web应用和GUI程序。RingoJS的Promise模块简化了异步编程,通过Deferred对象实现延迟执行,提高了程序的健壮性和可维护性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Ringo 是一个 JavaScript 平台

ECMA JavaScript 规范将该语言描述为面向对象的编程语言,用于在主机环境中执行计算和处理计算对象。每个用 JavaScript 编写的应用程序都需要一个主机环境,它提供特定于环境的对象和 API 来执行 I / O。 Ringo 为 JavaScript 提供了这样一个环境,并附带一组模块以使应用程序开发更容易。由于其作为通用编程语言的特性,JavaScript 可以用来解决各种各样的问题,而 Ringo 可以帮助您这么做。利用 Ringo,编写命令行工具,复杂的 Web 应用程序甚至基于 Java UI 技术的 GUI 应用程序都很容易。

脚本语言如 JavaScript 需要一个引擎来解释和执行程序。 Ringo 没有自己的引擎。相反,它使用 Mozilla Rhino,一种 Java 中的 JavaScript 实现。犀牛的最初发展始于 Netscape 时代,并一直持续到现在。基本思想是将 JavaScript 程序编译为 Java 字节码,Java 字节码可以由 Java 虚拟机(JVM)执行。犀牛还提供了对 Java 标准类库和其他每个 Java 类的轻松访问。这使得将现有的 Java 库集成到新的 JavaScript 应用程序变得很容易。例如:Ringo 不是编写自己的 I / O 系统,而是使用现有的 Java I / O 类,并将它们封装起来以提供从 JavaScript 更容易的访问。

Ringo 在服务器或专用机器上执行 JavaScript,而不是在 Web 浏览器上下文中执行。如果您已经从基于 HTML 的应用程序中了解 JavaScript,则这是主要区别。没有什么像一个窗口对象,你没有一个 DOM 来操纵 HTML 对象。尽管如此,很多事情会像你从浏览器中知道的那样。您可以使用 console.log() 调试到控制台,但也有专用的日志记录模块可用于更复杂的日志记录。

Ringo 最大的优势之一就是模块系统。 Ringo 并没有自己构建代码,而是拥有一个易于使用的模块系统。它基于 CommonJS 模块,这是用于保持代码可互换的服务器端 JavaScript 环境的规范。如果您了解 Node.js 的模块,您还知道如何在 Ringo 中编写模块。一个模块封装了 JavaScript 方法和变量,并将它们与其他模块隔离。

模块 ringo/promise

允许使用将在未来解决的deferred值。

Class Deferred

Instance Methods

Instance Properties

Class Promise

Instance Methods

Class PromiseList


Deferred ()

创建一个代表deferred值的对象。deferred对象有两个属性:一个 promise 对象和一个 resolve() 函数。

promise对象可用于注册promise最终解析时要调用的回调。

resolve函数用于解决promise被执行或失败。

Example

// --- sample output ---
// getDeferredValue() ...
// getDeferredValue() finished after 396 ms
// Resolved promise, got foo
// Total time:  2400 ms

const getDeferredValue = function () {
  const deferred = new Deferred();
  setTimeout(function() {
    deferred.resolve("foo");
  }, 2000);

  return deferred;
};

const start = Date.now();
console.log("getDeferredValue() ... ");

const def = getDeferredValue();
console.log("getDeferredValue() finished after",
  Date.now() - start, "ms");

def.promise.then(function(value) {
  console.log("Resolved promise, got", value);
  console.log("Total time: ", Date.now() - start, "ms");
});

Deferred.prototype. promise

promise对象可用于注册promise最终解析时要调用的回调。


Deferred.prototype. resolve (result, isError)

Resolve the promise.

Parameters

Objectresult

the result or error value

BooleanisError

if true the promise is resolved as failed


Promise

一个promise对象。 这个类不被导出,创建一个 deferred对象 来创建一个promise.


Promise.prototype. then (callback, errback)

注册回调函数和errback函数,在解析promise时调用。

Parameters

Functioncallback

called if the promise is resolved as fulfilled

Functionerrback

called if the promise is resolved as failed

Returns

Object

a new promise that resolves to the return value of the callback or errback when it is called.


Promise.prototype. wait (timeout)

等待promise被解决。

Parameters

Numbertimeout

optional time in milliseconds to wait for. If timeout is undefined wait() blocks forever.

Returns

Object

the value if the promise is resolved as fulfilled

Throws

如果promise被解析为失败,请将错误值作为对象


PromiseList (promise...)

PromiseList类允许将几个promise合并为一个。 它表示一个promise,它解析为一个对象数组,每个对象都包含一个值或错误属性,其中包含相应promise参数的值或错误。

PromiseList即使部分或全部部分promise解析为错误,也能成功解析。 处理函数负责检查每个单独的promise结果。

Example

// --- sample output ---
// Done!
// { value: 'i am ok' }
// { value: 1 }
// { error: 'some error' }

let d1 = Deferred(), d2 = Deferred(), d3 = Deferred();

// PromiseList accepts a promise or deferred object
let list = PromiseList(d1.promise, d2, d3);

list.then(function(results) {
  console.log("Done!");
  results.forEach(function(result) {
    console.dir(result);
  });
}, function(error) {
   console.error("Error :-(");
});

d2.resolve(1);
d3.resolve("some error", true);
d1.resolve("i am ok");

Parameters

Promise...promise...

any number of promise arguments.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值