我什么时候应该使用哪个?以下是一样的吗?
新的 Promise() 示例:
function multiRejectExample(){
return new Promise(function (resolve, reject){
if(statement){
console.log('statement 1');
reject(throw new Error('error'));
}
if(statement){
console.log('statement 2');
reject(throw new Error('error'));
}
});
}
Promise.try() 示例:
function tryExample(){
return Promise.try(function(){
if(statement){
console.log('statement 1');
throw new Error('error');
}
if(statement){
console.log('statement 2');
throw new Error('error');
}
});
}
最佳答案
在这种情况下,您可以主要使用其中一种(有一个行为差异)。第一个是标准的 promise 功能,可以与任何 promise 库一起使用。
Promise.try() 是 Bluebird 库专门实现的一项功能,不属于我所知道的任何标准流程。
使用 Promise.try() 的原因是如果您有一个返回 promise 的函数,但生成该 promise 的代码也可能导致同步异常。由于该异常不在任何 promise 处理程序中,因此您将混合使用错误处理。某些代码执行路径可能会导致返回将解决或拒绝的 promise ,而其他代码执行路径可能会引发异常。为了安全地编写代码,您必须响应 promise 并在变得笨拙的代码周围放置一个 try/catch block 。
Promise.try() 只是一种自动捕获任何异常并将其转化为拒绝的方法(类似于 .then() 处理程序中发生的情况)。
在你的两种情况下,Promise.try() 不会以这种方式让你受益,因为 new Promise() 回调已经捕获异常并将它们变成拒绝,所以该功能已经在那里为您完成。您可以在此处看到演示:http://jsfiddle.net/jfriend00/wLov9844/
Bluebird 文档提供了这个示例,它更清楚地显示了好处:
function getUserById(id) {
return Promise.try(function() {
if (typeof id !== "number") {
// Courtesy of Promise.try() this exception will be turned
// into a returned promise that is rejected with the
// exception as the reason
throw new Error("id must be a number");
}
return db.getUserById(id);
});
}
getUserById().then(successFn, errFn);
此处使用 Promise.try() 可确保 getUserById() 始终返回一个 promise,即使该方法中的代码同步抛出异常也是如此.这简化了 getUserById() 的使用,因为您始终可以只响应 promise 而不必围绕它使用自己的异常处理程序。
如果没有 Promise.try(),您可以像这样自己编写相同的代码(以捕获函数内所有可能的同步异常):
function getUserById(id) {
try {
if (typeof id !== "number") {
throw new Error("id must be a number");
}
return db.getUserById(id);
} catch(e) {
return Promise.reject(e);
}
}
getUserById().then(successFn, errFn);
或者,您可以这样编码:
function getUserById(id) {
if (typeof id !== "number") {
throw new Error("id must be a number");
}
return db.getUserById(id);
}
try {
getUserById().then(successFn, errFn);
} catch(e) {
errFn(e);
}
据推测,您可以看到 Promise.try() 在某些情况下如何简化事情。
仅供引用,在您的第一个示例中,您使用的语法无效。你可以这样做:
reject(throw new Error('error'));
我假设你的意思是这样的:
reject(new Error('error'));
虽然我不认为这真的是您要问的问题,但如果您自己不返回 promise ,Promise.try() 也会自动返回已解决的 promise 。由于通过您的第一个示例的一条路径没有解决或拒绝,因此这将导致您的两个示例有所不同。
关于javascript - Bluebird.JS Promise : new Promise(function (resolve, reject){}) vs Promise.try(function(){}),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32148305/
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
“输出”是一个序列化的OpenStruct。定义标题try(:output).try(:data).try(:title)结束什么会更好?:) 最佳答案 或者只是这样:deftitleoutput.data.titlerescuenilend 关于ruby-on-rails-更好的替代方法try(:output).try(:data).try(:name)?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c
我遇到了一个非常奇怪的问题,我很难解决。在我看来,我有一个与data-remote="true"和data-method="delete"的链接。当我单击该链接时,我可以看到对我的Rails服务器的DELETE请求。返回的JS代码会更改此链接的属性,其中包括href和data-method。再次单击此链接后,我的服务器收到了对新href的请求,但使用的是旧的data-method,即使我已将其从DELETE到POST(它仍然发送一个DELETE请求)。但是,如果我刷新页面,HTML与"new"HTML相同(随返回的JS发生变化),但它实际上发送了正确的请求类型。这就是这个问题令我困惑的
我需要从json记录中获取一些值并像下面这样提取curr_json_doc['title']['genre'].map{|s|s['name']}.join(',')但对于某些记录,curr_json_doc['title']['genre']可以为空。所以我想对map和join()使用try函数。我试过如下curr_json_doc['title']['genre'].try(:map,{|s|s['name']}).try(:join,(','))但是没用。 最佳答案 你没有正确传递block。block被传递给参数括号外的方法
我有这个:AccountSummary我想单击该链接,但在使用link_to时出现错误。我试过:bot.click(page.link_with(:href=>/menu_home/))bot.click(page.link_with(:class=>'top_level_active'))bot.click(page.link_with(:href=>/AccountSummary/))我得到的错误是:NoMethodError:nil:NilClass的未定义方法“[]” 最佳答案 那是一个javascript链接。Mechan
我今天制作了一个非常小的ruby脚本,它使用正则表达式来跟踪具有特定名称的文件中的某些内容,并在添加其替换内容之前删除该内容。(否则在迭代过程中会出现问题)。我不太习惯使用ruby(自从1-2周前我的假期工作开始后才开始使用它),但我的一个习惯是在迭代时避免接触列表(或大多数其他使用索引的ADT)在它们之上(删除某些内容),与我使用的语言无关。经过一些搜索,我发现了一些可以提供帮助的Array函数。现在,我正在使用Array.reject!并且脚本按照我希望的方式运行,但老实说我无法弄清楚为什么Array.reject!{|行|line=~regex}跳过数组中的对象没有问题。
我需要遍历一个数组,并在Perl中有条件地删除元素。我知道slice,但不确定如何在foreach上下文中使用它。在Ruby中,有reject!:foo=[2,3,6,7]foo.reject!{|x|x>3}pfoo#outputs"[2,3]"是否有Perl等价物? 最佳答案 您可以使用Perl的grep这就像一个反向拒绝:它将保留所有满足条件的项目。所以rejectx>3必须变成grepx:@foo=(2,3,6,7);@foo=grep{$_条件不一定是数字比较,但可以是在bool上下文中有效的任何内容,例如匹配正则表达式。
我看到有关未找到文件min.map的错误消息:GETjQuery'sjquery-1.10.2.min.mapistriggeringa404(NotFound)截图这是从哪里来的? 最佳答案 如果ChromeDevTools报告.map文件的404(可能是jquery-1.10.2.min.map、jquery.min.map或jquery-2.0.3.min.map,但任何事情都可能发生)首先要知道的是,这仅在使用DevTools时才会请求。您的用户不会遇到此404。现在您可以修复此问题或禁用sourcemap功能。修复:获取文
我有一个用Rails3编写的站点。我的帖子模型有一个名为“内容”的文本列。在帖子面板中,html表单使用tinymce将“content”列设置为textarea字段。在首页,因为使用了tinymce,post.html.erb的代码需要用这样的原始方法来实现。.好的,现在如果我关闭浏览器javascript,这个文本区域可以在没有tinymce的情况下输入,也许用户会输入任何xss,比如alert('xss');.我的前台会显示那个警告框。我尝试sanitize(@post.content)在posts_controller中,但sanitize方法将相互过滤tinymce样式。例如
我正在尝试在ruby中获取对Object#try的访问权限。我认为只包含activesupport就可以解决问题,但事实并非如此。irb(main):001:0>require'rubygems'=>trueirb(main):002:0>require'active_support'=>trueirb(main):003:0>o=Object.new=>#irb(main):004:0>o.respond_to?:try=>falseirb(main):005:0>如何访问Object#try? 最佳答案 要尝试,您需要做的就