- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经组装了一个在我的页面上使用的小工具,并且在大多数情况下它似乎都能正常工作,但是当我尝试将其插入Q.js<时,我的行为有点奇怪
.
通常,据我了解,您可以通过这种方式调用函数。
Q(manager.tasks.init)
.then(manager.tasks.start)
.then(manager.tasks.fulfill)
.then(manager.tasks.finish);
但是我似乎无法做到这一点,相反我必须调用它们并像函数一样显式调用它们,就像这样。
Q(manager.tasks.init())
.then(manager.tasks.start())
.then(manager.tasks.fulfill())
.then(manager.tasks.finish());
完整的代码可以在这里看到;
现在,我可以使用括号,但我不明白为什么它这样做。我想了解这里发生了什么,因此非常感谢任何信息。
最佳答案
在上面的评论和我的答案的评论中记录我们经历的一些事情......
您的上述解决方案实际上都没有正确编码。第一个有问题,因为当 Q 调用回调时,this
不会被设置属性。
当你这样做时:
Q(manager.tasks.init)
.then(manager.tasks.start)
.then(manager.tasks.fulfill)
.then(manager.tasks.finish);
Q 将调用这些方法,但 this
指针不会像您想要的那样设置为 manager.tasks
。因此,当您在方法中执行此类操作时:
$(this).trigger("init:begin");
那么this
将不是你想要的,它会抛出异常并停止执行。您可以通过执行以下操作来解决该问题:
Q(manager.tasks.init.bind(manager.tasks))
.then(manager.tasks.start.bind(manager.tasks))
.then(manager.tasks.fulfill.bind(manager.tasks))
.then(manager.tasks.finish.bind(manager.tasks));
这将导致 this
设置为 manager.tasks
。或者,您可以删除这些方法中 this
的任何使用,以便它们成为静态方法(这似乎是您选择执行的操作)。
第二个没有像预期那样将函数引用传递给 .then()
。
当你这样做时:
Q(manager.tasks.init())
.then(manager.tasks.start())
.then(manager.tasks.fulfill())
.then(manager.tasks.finish());
JS 解释器立即调用您的函数(这就是当您将 ()
放在末尾时发生的情况)并将这些函数的返回值传递给每个 .then( )
行。那不是你想要的。 .then()
希望将函数引用传递给它,以便 Promise 库可以稍后执行该函数。在您的情况下,您的函数返回的 promise 不是您应该传递给 .then()
的内容。
因为这些方法中没有实际的异步操作,所以这似乎可以工作,因为它按顺序调用操作,但是只要其中任何一个方法中有一个实际解决 promise 的异步操作,它就不起作用正确。
<小时/>对于您的fulfill方法的问题,它需要像这样,您在reduce操作中使用您创建的名为results
的延迟/ promise 。我还更改了它以在 setTimeout()
之前运行reduce,因为它对我来说似乎更干净(更容易理解)。您正在设置要完成的所有工作,然后在 setTimeout()
中通过解决链中的第一个延迟来开始工作。
然后,它返回从 list.reduce()
操作返回的链式 Promise,并使用链式 .then()
处理程序来了解何时输出“fulfill:end”
消息。
manager.tasks.fulfill = function () {
// alert the task manager that we're beginning this phase
$(manager.tasks).trigger("fulfill:begin");
// create a placeholder for the result of all of the items in the list
var results = Q.defer();
setTimeout(function(){
// resolve the first defer we created to
// let the `.then()` chain start to run
results.resolve();
}, 6000);
// now add all then `.then()` onto the results
// these functions won't run yet because the first defer has not yet resolved
return list.reduce(function(i, f) {
return i.then(f);
}, results.promise).then(function() {
// alert the task manager that we're ending this phase
// after all the callback promises have finished
$(manager.tasks).trigger("fulfill:end");
});
};
<小时/>
我认为如果您的回调返回这样的 promise ,.enqueue()
问题将会得到解决:
manager.tasks.enqueue(function(deferred){
return function(){
setTimeout(function(){
console.log('test');
deferred.resolve();
}, 3000);
return deferred.promise;
};
});
如果是我,我可能会更改 .enqueue()
实现,以便它处理 promise 的返回(因为它是创建它的人),但这是一个快速的解决方案这是为了确保您的回调在执行时返回 promise 。
您可以在此处查看 jsFiddle 的派生 http://jsfiddle.net/jfriend00/JxJVs/实现这些更改后,可以生成您在 JPEG 中显示的精确输出。
关于jquery - 使用 Q.js "then"不带括号调用函数时遇到困难,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24664101/
为了让我的代码几乎完全用 Jquery 编写,我想用 Jquery 重写 AJAX 调用。 这是从网页到 Tomcat servlet 的调用。 我目前情况的类似代码: var http = new
我想使用 JNI 从 Java 调用 C 函数。在 C 函数中,我想创建一个 JVM 并调用一些 Java 对象。当我尝试创建 JVM 时,JNI_CreateJavaVM 返回 -1。 所以,我想知
环顾四周,我发现从 HTML 调用 Javascript 函数的最佳方法是将函数本身放在 HTML 中,而不是外部 Javascript 文件。所以我一直在网上四处寻找,找到了一些简短的教程,我可以根
我有这个组件: import {Component} from 'angular2/core'; import {UserServices} from '../services/UserService
我正在尝试用 C 实现一个简单的 OpenSSL 客户端/服务器模型,并且对 BIO_* 调用的使用感到好奇,与原始 SSL_* 调用相比,它允许一些不错的功能。 我对此比较陌生,所以我可能会完全错误
我正在处理有关异步调用的难题: 一个 JQuery 函数在用户点击时执行,然后调用一个 php 文件来检查用户输入是否与数据库中已有的信息重叠。如果是这样,则应提示用户确认是否要继续或取消,如果他单击
我有以下类(class)。 public Task { public static Task getInstance(String taskName) { return new
嘿,我正在构建一个小游戏,我正在通过制作一个数字 vector 来创建关卡,该数字 vector 通过枚举与 1-4 种颜色相关联。问题是循环(在 Simon::loadChallenge 中)我将颜
我有一个java spring boot api(数据接收器),客户端调用它来保存一些数据。一旦我完成了数据的持久化,我想进行另一个 api 调用(应该处理持久化的数据 - 数据聚合器),它应该自行异
首先,这涉及桌面应用程序而不是 ASP .Net 应用程序。 我已经为我的项目添加了一个 Web 引用,并构建了各种数据对象,例如 PayerInfo、Address 和 CreditCard。但问题
我如何告诉 FAKE 编译 .fs文件使用 fsc ? 解释如何传递参数的奖励积分,如 -a和 -target:dll . 编辑:我应该澄清一下,我正在尝试在没有 MSBuild/xbuild/.sl
我使用下划线模板配置了一个简单的主干模型和 View 。两个单独的 API 使用完全相同的配置。 API 1 按预期工作。 要重现该问题,请注释掉 API 1 的 URL,并取消注释 API 2 的
我不确定什么是更好的做法或更现实的做法。我希望从头开始创建目录系统,但不确定最佳方法是什么。 我想我在需要显示信息时使用对象,例如 info.php?id=100。有这样的代码用于显示 Game.cl
from datetime import timedelta class A: def __abs__(self): return -self class B1(A):
我在操作此生命游戏示例代码中的数组时遇到问题。 情况: “生命游戏”是约翰·康威发明的一种细胞自动化技术。它由一个细胞网格组成,这些细胞可以根据数学规则生存/死亡/繁殖。该网格中的活细胞和死细胞通过
如果我像这样调用 read() 来读取文件: unsigned char buf[512]; memset(buf, 0, sizeof(unsigned char) * 512); int fd;
我用 C 编写了一个简单的服务器,并希望调用它的功能与调用其他 C 守护程序的功能相同(例如使用 ./ftpd start 调用它并使用 ./ftpd stop 关闭该实例)。显然我遇到的问题是我不知
在 dos 中,当我粘贴此命令时它会起作用: "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" https://google.
在 dos 中,当我粘贴此命令时它会起作用: "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" https://google.
我希望能够从 cmd 在我的 Windows 10 计算机上调用 python3。 我已重新安装 Python3.7 以确保选择“添加到路径”选项,但仍无法调用 python3 并使 CMD 启动 P
我是一名优秀的程序员,十分优秀!