【问题标题】:Angular datatable fnDraw() doesn't work角度数据表 fnDraw() 不起作用
【发布时间】:2013-10-04 06:25:09
【问题描述】:

我在一个角度指令(我的指令: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 ' 为空

我在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] );

【问题讨论】:

    标签: javascript angularjs datatable


    【解决方案1】:

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

    这解决了问题:

    scope.dataTable.fnSettings().oInstance.fnFilter()
    

    【讨论】:

      【解决方案2】:

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

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2015-09-05
        • 1970-01-01
        • 2018-12-25
        • 2016-10-24
        • 2016-10-20
        相关资源
        最近更新 更多