JavaScript对象失去了跨函数的引用

时间:2013-11-22 16:34:35

标签: javascript jquery sapui5

我正在使用一个小的待办事项列表应用程序测试SAPUI5框架。我有一个数据库并通过REST服务访问数据。我可以将所有内容放入我的UI,从UI进入数据库。

但是,我正在JSON模型中保存数据库数据的引用,该模型映射到我在UI上显示的表。当我尝试添加/删除元素时,对数据库的写入似乎正常工作,但我的实习模型变量在不同的函数调用之间失去了引用(例如“initToDoModel”和“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函数,从db获取数据,将其映射到JSONModel对象。然后当我单击我页面上的Add Button时,会调用addToDo函数,并且需要更新此时未定义的缓存JSONModel。

我是JavaScript的新手,所以也许有人可以解释那里发生的事情。

1 个答案:

答案 0 :(得分:5)

您可以在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(); 
        });  
    },