2016-06-24 2 views
1

Я работаю с AngularJS и угловым datatable, и я хочу работать с событием подряд, я настроил контроллер для прослушивания события, но он не работает. Мой код:Angular - Datatable click row event

HTML

<div class="panel panel-flat"> 
    <div class="panel-heading"> 
     <h6 class="panel-title">Planilla</h6> 
    </div> 
    <div class="panel-heading"> 
    <table class="table datatable-basic table-hover" datatable="ng" dt-options="empleadoList.dtOptions" dt-column-defs="empleadoList.dtColumnDefs" > 
     <thead> 
      <tr> 
       <th style="width: 30px;">Nro.</th> 
       <th>Nombre Completo</th> 
       <th class="col-md-2">DNI</th> 
       <th class="col-md-2">Celular</th> 
       <th class="col-md-2">Teléfono</th> 
      </tr> 
     </thead> 
     <tbody> 
      <tr ng-repeat="empleado in empleadoList.empleados"> 
       <td style="width: 30px;">{{$index + 1}}</td> 
       <td> <span class="text-muted"><i class="icon-user"></i>{{empleado.apellidoPaterno}} {{empleado.apellidoMaterno}} {{empleado.nombre}}</span></td> 
       <td><span class="text-success-600"><span class="status-mark border-blue position-left"></span>{{empleado.dni}}</span></td> 
       <td><span class="text-success-600"><i class="icon-mobile position-left"></i> {{empleado.celular}}</span></td> 
       <td><h6 class="text-semibold"><i class="icon-phone position-left"></i> {{empleado.telefono}}</h6></td> 
      </tr> 
     </tbody> 
    </table> 
    </div> 
</div> 

controller.js

App.controller('EmpleadoListController', function($scope,$resource,EmpleadoService,DTOptionsBuilder,DTColumnDefBuilder) { 

$scope.dtOptions = DTOptionsBuilder.newOptions() 
    .withDisplayLength(10) 
    .withOption('bLengthChange', false) 
    .withPaginationType('full_numbers') 
    .withOption('rowCallback', rowCallback); 
$scope.dtColumnDefs = [ 
        DTColumnDefBuilder.newColumnDef(0), 
        DTColumnDefBuilder.newColumnDef(1), 
        DTColumnDefBuilder.newColumnDef(2), 
        DTColumnDefBuilder.newColumnDef(3), 
        DTColumnDefBuilder.newColumnDef(4) 
       ]; 

function rowCallback(nRow, aData, iDisplayIndex, iDisplayIndexFull) { 
    $('td', nRow).unbind('click'); 
    $('td', nRow).bind('click', function() { 
     $scope.$apply(function() { 
      console.log('click row'); 
     }); 
    }); 
    return nRow; 
} 

EmpleadoService.fetch().then(
     function(response){ 
      return $scope.empleadoList = { empleados: response.data}; 
     }, 
     function(errResponse){ 
      console.error('Error while fetching users'); 
      return $q.reject(errResponse); 
     } 
); 
}); 

app.js

'use strict'; 
var App = angular.module('myApp', ['ngRoute','ngResource','datatables']); 
App.config(function($routeProvider) { 
    var resolveEmpleados = { 
    empleados: function (EmpleadoService) { 
    return EmpleadoService.fetch(); 
    } 
}; 

$routeProvider 
.when('/planilla', { 
    controller:'EmpleadoListController as empleadoList', 
    templateUrl:'static/js/planilla.html', 
    }); 
}); 

Спасибо за все.

ответ

3

Поскольку вы используете угловой путь для рендеринга, почему бы не использовать ng-click, а также:

<tr ng-repeat="empleado in empleadoList.empleados" ng-click="click(empleado)"> 
$scope.click = function(empleado) { 
    console.log(empleado.apellidoPaterno+' clicked') 
} 
0

Вы были почти там. Элемент row доступен из функции обратного вызова строки как nRow.

Так, например, вы можете, например, изменить цвет строки переключая выбранный класс следующим образом

$scope.$apply(function() { 
     $(nRow).toggleClass('selected'); 
     // do your stuff with the row here 
}); 

nRow дает вам доступ к элементу строки.

Затем есть aData, которая дает вам массив, содержащий значения элементов td или столбца в этой строке.

$scope.$apply(function() { 
     console.log(aData); 
     // do your stuff with the row here 
}); 
0

Я вижу, что вы пропустите функцию в вашем коде:

function someClickHandler(info) { 
    vm.message = info.id + ' - ' + info.firstName; 
} 

function rowCallback(nRow, aData, iDisplayIndex, iDisplayIndexFull) { 
    // Unbind first in order to avoid any duplicate handler (see https://github.com/l-lin/angular-datatables/issues/87) 
    $('td', nRow).unbind('click'); 
    $('td', nRow).bind('click', function() { 
     $scope.$apply(function() { 
      vm.someClickHandler(aData); 
     }); 
    }); 
    return nRow; 
} 

и не забывайте об этом:

vm.someClickHandler = someClickHandler; 

вы можете прочитать документ в here

Надежда поможет вам ,

 Смежные вопросы

  • Нет связанных вопросов^_^