weixin_33738555 2015-03-02 10:31 采纳率: 0%
浏览 69

声明的函数未调用

I have a function to fetch my data from backend. once the data is loaded i am calling a function which is sent as callback. but i am getting error as undefined not a function

here is the code:

var initDataTable = function () {

      var getDableData = function (url,callback) {
            $.getJSON(url)
              .then(function (data) {
                callback(data);
            });
      };

      return {

        init : function (dataAssests) {
          this.container = dataAssests.container;
          this.headerNames = dataAssests.names;          
          getDableData(dataAssests.url, this.dataReceiver); //getting required data
        },

        dataReceiver : function (data) {
            this.tableData = data;
            this.tableMaker(); //not calling error Uncaught TypeError: undefined is not a function.
        },

        tableMaker : function () {
          console.log(this.tableData);
        }

      };
};

//tabular data starts...
var dataAssests = {
                    container: $('.dataTable'), 
                    url : 'https://tcs.firebaseio.com/d/DocPageDetails/d/Organizations.json', 
                    names : ['Organization Name', 'Zip Code', 'Telephone', 'Organization TypeName' ]
                  };

var dataTableFrist = initDataTable().init(dataAssests);
//tabular data ends...

jsfiddle

  • 写回答

1条回答 默认 最新

  • George_Fal 2015-03-02 10:37
    关注

    The problem is not that callback is not defined, it is inside dataReceiver where this is not referring to the object what you are expecting.

    Since you are invoking the callback without a context, this inside dataReceiver is referring to the window object so this.tableMaker is undefined thus the error.

    One possible solution is to use Function.bind() to pass a custom execution context to the callback method

    getDableData(dataAssests.url, this.dataReceiver.bind(this));
    

    Demo: Fiddle

    评论

报告相同问题?