Prototype和Ajax.Request的范围
-
23-08-2019 - |
题
我遇到了麻烦原型的Ajax.Request的类中的正确范围。我正在试图做的是写一个简单的API,它包装的Ajax请求:
API = Class.create({
initialize:function(api_token)
{
this.api_token = api_token;
this.request_uri = new Template('/api/#{api_token}/#{resource}.json');
this.status = 0;
this.last_result = null;
},
some_api_call:function()
{
var result = this._request('resource', {'id':1});
// and so on...
},
_request:function(resource, params)
{
var uri = this.request_uri.evaluate({"api_token":this.api_token,"resource":resource});
new Ajax.Request(uri,
{
contentType:'application/json',
method:'get',
parameters:params,
onSuccess:function(r)
{
alert(this);
this.last_result = r.responseJSON;
this.status = r.status;
}
});
return this.last_result;
}
});
当我在的onSuccess()方法我预期+这个+指母体对象,但它给我DOMWindow。我似乎无法获取响应数据到API类的。我想,这是愚蠢的东西(绑定?),但我似乎无法想到今天这一个。
由于
解决方案
好。我错过了更大的问题。我请求异步所以它的是的设置的结果,只是没有马上。说句公道话,这也是一个结合的问题。下面是适当的请求:
_request:function(resource, params)
{
var uri = this.request_uri.evaluate({"api_token":this.api_token,"resource":resource});
new Ajax.Request(uri,
{
asynchronous: false,
contentType:'application/json',
method:'get',
parameters:params,
onSuccess:function(r)
{
this.last_result = r.responseJSON;
this.status = r.status;
}.bind(this)
});
alert(this.status);
return this.last_result;
}
其他提示
您的解决方案不应该工作?
您需要使用嵌套函数上述局部变量,然后将它们转换成“这个”范围:
_request:function(resource, params)
{
var uri = this.request_uri.evaluate({"api_token":this.api_token,"resource":resource});
var last_result = "";
var status = "";
new Ajax.Request(uri,
{
asynchronous: false,
contentType:'application/json',
method:'get',
parameters:params,
onSuccess:function(r)
{
last_result = r.responseJSON;
status = r.status;
}
});
this.last_result = last_result;
this.status = status;
alert(this.status);
return this.last_result;
}
不隶属于 StackOverflow