0

我在一个角度指令(我的指令:https ://gist.github.com/jianbo/6734624 )中使用数据表库,类似于 Ventura 建议的Using Jquery Datatable with AngularJs。我的 fnDraw 有问题,在我的应用程序中,我有多个网页,每个网页都有一个数据表,因为我使用 Angular 页面根本不会重新加载。

  $(".resource-filter").live "change", (event) ->
    scope.dataTable.fnDraw() // This is where error triggered 

  $("#sSearch").live "keyup", (event) ->
    scope.dataTable.fnDraw() // This is where error triggered

我的数据表仍然可以在每一页上加载数据,但是在访问了多个页面之后,然后尝试调用 scope.dataTable.fnDraw() 来过滤我的数据表,我得到了这个错误:Uncaught TypeError: Cannot read property 'oFeatures' of null

我在reDraw函数中放了一些断点,发现oSettings(第5557行)为空,在_fnSettingsFromNode函数中我可以看到DataTable.settings[i].nTable === nTable(第4611行)总是返回false,我可以发现 DataTable.settings 包含多个数据表,但是 for 循环与当前的不匹配

任何的想法?

    function _fnSettingsFromNode ( nTable )
     {
      for ( var i=0 ; i<DataTable.settings.length ; i++ )
      {
        if ( DataTable.settings[i].nTable === nTable )
        {
          return DataTable.settings[i];
        }
      }

      return null;
    } 

    oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
4

2 回答 2

1

似乎是当有多个Datatable实例时,“scope.dataTable”无法引用当前的Datatable。

这解决了问题:

scope.dataTable.fnSettings().oInstance.fnFilter()
于 2013-09-30T20:36:40.547 回答
0

尝试更改.live.on,因为.live已弃用。

于 2013-12-24T07:22:03.253 回答