初学者javascript问题
这应该很容易,但由于我是编程新手,特别是javascript,我无法理解 假设我有以下javascript代码:初学者javascript问题,javascript,ajax,prototypejs,Javascript,Ajax,Prototypejs,这应该很容易,但由于我是编程新手,特别是javascript,我无法理解 假设我有以下javascript代码: var InjectClientValue = Class.create(); InjectClientValue.prototype = { initialize: function( sourceElement, eventElement, updateElement ) { this.sourceElement = $(sourceElement);
var InjectClientValue = Class.create();
InjectClientValue.prototype = {
initialize: function( sourceElement, eventElement, updateElement ) {
this.sourceElement = $(sourceElement);
this.element = $(eventElement);
this.updateElement =$(updateElement)
this.element.observe('click',this.onClick.bindAsEventListener(this));
},
onClick: function(event) {
new Ajax.Request(this.element.href+"/"+this.sourceElement.value, {
method:'get',
onSuccess: function(transport) {
//How do I access the instance variable updateElement in InjectClientValue_
//updateElement.update(transport.responseJSON.content);
}
});
event.stop();
}
}
我需要的是从onSuccess of new Ajax.Request访问initialize中设置的变量updateElement。我该怎么做?试试这个:
onClick: function(event) {
var thisVariable = this;
new Ajax.Request(this.element.href+"/"+this.sourceElement.value, {
method:'get',
onSuccess: function(transport) {
thisVariable.updateElement.update(transport.responseJSON.content);
}
因为您已经有一个类的实例作为“InjectClientValue”,所以可以使用它来引用对象并对其调用方法。
onClick:函数(事件){
新的Ajax.Request(this.element.href+“/”+this.sourceElement.value、{
方法:'get',
onSuccess:功能(传输){
InjectClientValue.updateElement.update(transport.responseJSON.content);
}
onClick: function(event) {
new Ajax.Request(this.element.href+"/"+this.sourceElement.value, {
method:'get',
onSuccess: function(transport) {
InjectClientValue.updateElement.update(transport.responseJSON.content);
}