JavaScript对象在函数之间失去引用



我正在用一个小的待办事项列表应用程序测试SAPUI5框架。我有一个数据库,并通过REST服务访问数据。我能够把所有的东西都输入到我的UI中,并从UI进入数据库。

然而,我将数据库数据的引用保存在JSON模型中,该模型映射到我在UI上显示的表。当我尝试添加/删除元素时,对数据库的写入似乎可以正常工作,但我的内部模型变量在不同的函数调用(例如"initToDoModel"one_answers"addToDo")之间失去了引用。这是代码:

  sap.ui.controller("sapui5_test.SAPUI5_Test", {
  //THIS IS THE REFFERENCE
  todoModel : null,            
        addTodo : function(text) {  
            this.doAjax("/add", {  
                text : text  
            }).done(function(todo) { 
                //HERE todoModel IS UNDEFINED BUT WAS SET IN initTodoModel
                this.todoModel.getProperty("/").push(todo); 
                this.todoModel.updateBindings();
                this.getView().rerender(); 
            });  
        },  
        initTodoModel : function() {    
            var oModel = new sap.ui.model.json.JSONModel();
            var aData = jQuery.ajax({
                type : "GET",
                contentType : "application/json",
                url : "http://sapm04.ibsolution.local:50000/demo.sap.com~d337_resttest_web/rest/todo/init/",
                dataType : "json",
                async: false,
                success : function(data,textStatus, jqXHR) {
                    oModel.setData({modelData : data});
                    //HERE THE todoModel IS SET
                    this.todoModel = oModel;
                    alert("Ok");
                }
            });
            return oModel;
        },  
        doAjax : function(path, content, type, async) {  
            var params = {  
                url : "http://sapm04.ibsolution.local:50000/demo.sap.com~d337_resttest_web/rest/todo" + path,  
                dataType : "json",  
                contentType : "application/json",  
                context : this, 
                //async : false,
                cache : false  
            };  
            params["type"] = type || "POST";  
            if (async === false) {  
                params["async"] = async;  
            }  
            if (content) {  
                params["data"] = JSON.stringify(content);  
            }  
            return jQuery.ajax(params);  
        },  
        getTodo : function(id) {  
            var index, todo;  
            jQuery.each(this.todoModel.getProperty("/"), function(i, t) {  
                if (t.id === id) {  
                    index = i;  
                    todo = t;  
                }  
            });  
            return {  
                index : index,  
                todo : todo  
            };  
        }
    });

因此,每次加载页面时都会调用initToDoModel函数,从数据库获取数据,并将其映射到JSONModel对象中。然后,当我单击页面上的添加按钮时,会调用addToDo函数,并需要更新缓存的JSONModel,该函数此时尚未定义。

我是JavaScript的新手,所以也许有人可以解释一下那里发生了什么。

您可以在AJAX回调中使用console.log(this);,您可能会看到它引用了window对象。

通过在AJAX调用之前将this所需的上下文存储在变量中,可以维护对当前对象的引用。

addTodo : function(text) {  
        var that = this;
        this.doAjax("/add", {  
            text : text  
        }).done(function(todo) { 
            //HERE todoModel IS UNDEFINED BUT WAS SET IN initTodoModel
            that.todoModel.getProperty("/").push(todo); 
            that.todoModel.updateBindings();
            that.getView().rerender(); 
        });  
    },  

最新更新