初学者javascript问题

初学者javascript问题,javascript,ajax,prototypejs,Javascript,Ajax,Prototypejs,这应该很容易,但由于我是编程新手,特别是javascript,我无法理解 假设我有以下javascript代码: var InjectClientValue = Class.create(); InjectClientValue.prototype = { initialize: function( sourceElement, eventElement, updateElement ) { this.sourceElement = $(sourceElement);

这应该很容易,但由于我是编程新手,特别是javascript,我无法理解

假设我有以下javascript代码:

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); }