angularjs - Angular `ng-click` 在 DataTables 表行中不起作用

标签 angularjs datatables

我有一个 Angular 也在使用 的应用程序jquery.dataTables .当我使用 数据表 使用 ng-click 构建动态表表数据中的 angular 指令,它不会触发 ng-click事件。

我怀疑我需要使用 Angular $compile服务,但我没有成功找到清晰的文档或示例。

任何帮助将不胜感激。

更新 :我在 DataTables 方法中的 createdRow 选项中添加了一些代码。我现在似乎要开火了,但我收到一个错误

0x800a01b6 - JavaScript runtime error: Object doesn't support property or method '$apply'



这是我的代码:

var app = angular.module('appy', []);
app.controller('myCtrl', [
  function() {
    var _this = this;

    $('#report').DataTable({
      data: [{
        "LastName": "Doe",
        "Link": "<button type=\"button\" ng-click=\"Ctrl.dataTablesAlert()\">Test Alert</a>"
      }],
      columns: [{
        "title": "Last Name",
        "data": "LastName"
      }, {
        "title": "Actions",
        "data": "Link"
      }],
      createdRow: function(row, data, dataIndex) {
        $compile(angular.element(row).contents())(_this);
      }
    });

    this.buttonAlert = function() {
      $('#buttondiv').addClass('success');
    };

    this.htmlAlert = function() {
      $('#htmltablediv').addClass('success');
    };

    this.dataTablesAlert = function() {
      $('#datatablediv').addClass('success');
    };

  }
]);
  div {
    margin-top: 15px;
    padding: 5px;
  }
  div.borderdiv {
    border: 1px solid black;
  }
  td {
    border: 1px solid black;
    padding: 2px
  }
  .success {
    background-color: green;
  }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<link href="https://cdn.datatables.net/1.10.13/css/jquery.dataTables.min.css" rel="stylesheet"/>
<script src="https://cdn.datatables.net/1.10.13/js/jquery.dataTables.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>

<div ng-app="appy" ng-controller="myCtrl as Ctrl">
  <div id="buttondiv" class=borderdiv>
    <h4>Button with ng-click</h4>
    <button type="button" ng-click="Ctrl.buttonAlert()">Test Alert</button>
  </div>

  <div id="htmltablediv" class="borderdiv">
    <h4>HTML Table with ng-click</h4>
    <table>
      <tr>
        <td>Last Name</td>
        <td>Actions</td>
      </tr>
      <tr>
        <td>Doe</td>
        <td>
          <button ng-click="Ctrl.htmlAlert()">
            Test Alert
          </button>
        </td>
      </tr>
    </table>
  </div>

  <div id="datatablediv" class="borderdiv">
    <h4>DataTables with ng-click</h4>
    <table id="report" class="display"></table>
  </div>

</div>

最佳答案

$compile接收一段 HTML 并返回所谓的链接函数。这个函数需要一个 $scope这将用于完成所有数据绑定(bind)。

由于您使用的是 ,这可能会让人感到困惑。 Controller 为 语法(这是一件好事),所以你不直接处理 $scope .

这里需要做的两件事是注入(inject)$compile$scope进入你的 Controller ,然后使用它们。

//Using array injector notation here
app.controller('myCtrl', 
['$scope','$compile',
  function($scope, $compile) {
     //snip...
  }
]);

稍后当你链接你的行时,你可以用注入(inject)的 $scope 调用它。像这样:
$compile(angular.element(row).contents())($scope);

如果您运行下面的代码片段,您可以看到一切都按预期工作。

var app = angular.module('appy', []);
app.controller('myCtrl', ['$scope','$compile',
  function($scope, $compile) {
    var _this = this;

    $('#report').DataTable({
      data: [{
        "LastName": "Doe",
        "Link": "<button type=\"button\" ng-click=\"Ctrl.dataTablesAlert()\">Test Alert</a>"
      }],
      columns: [{
        "title": "Last Name",
        "data": "LastName"
      }, {
        "title": "Actions",
        "data": "Link"
      }],
      createdRow: function(row, data, dataIndex) {
        $compile(angular.element(row).contents())($scope);
      }
    });

    this.buttonAlert = function() {
      $('#buttondiv').addClass('success');
    };

    this.htmlAlert = function() {
      $('#htmltablediv').addClass('success');
    };

    this.dataTablesAlert = function() {
      $('#datatablediv').addClass('success');
    };

  }
]);
div {
    margin-top: 15px;
    padding: 5px;
  }
  div.borderdiv {
    border: 1px solid black;
  }
  td {
    border: 1px solid black;
    padding: 2px
  }
  .success {
    background-color: green;
  }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<link href="https://cdn.datatables.net/1.10.13/css/jquery.dataTables.min.css" rel="stylesheet"/>
<script src="https://cdn.datatables.net/1.10.13/js/jquery.dataTables.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>

<div ng-app="appy" ng-controller="myCtrl as Ctrl">
  <div id="buttondiv" class=borderdiv>
    <h4>Button with ng-click</h4>
    <button type="button" ng-click="Ctrl.buttonAlert()">Test Alert</button>
  </div>

  <div id="htmltablediv" class="borderdiv">
    <h4>HTML Table with ng-click</h4>
    <table>
      <tr>
        <td>Last Name</td>
        <td>Actions</td>
      </tr>
      <tr>
        <td>Doe</td>
        <td>
          <button ng-click="Ctrl.htmlAlert()">
            Test Alert
          </button>
        </td>
      </tr>
    </table>
  </div>

  <div id="datatablediv" class="borderdiv">
    <h4>DataTables with ng-click</h4>
    <table id="report" class="display"></table>
  </div>

</div>

关于angularjs - Angular `ng-click` 在 DataTables 表行中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41641601/

相关文章:

javascript - javascript中具有公共(public)回调的类

javascript - 如何按日期(作为标准)对数据表进行排序,同时保持其他列可用的排序选项?

jquery - jQuery Datatables 可以更改从服务器返回的值以供客户端查看吗?

javascript - 如何重新初始化 jquery 数据表

javascript - 如何使用 jquery 在相邻的 <td></td> 元素中添加/减去值

javascript - 如何在 ng-repeat 循环中初始化输入复选框的 ng-model

Angular : How do i override directive's style in my view?

数据表 + 如何将服务器端处理代码与文件导出代码结合起来

javascript - 如何在工厂中移动 Controller 代码

javascript - 在 Xampp Web 服务器上设置 AngularJS 和 NodeJS