我使用动态列的ng-table,使用在
http://bazalt-cms.com/ng-table/example/20找到的创建者示例
它工作得很好,直到我试图用transclude包装一个指令,女巫导致标题消失,如http://plnkr.co/edit/mjYVEf所示.
的index.html
<!DOCTYPE html> <html> <head> <script data-require="angular.js@*" data-semver="1.2.0-rc3-nonmin" src="http://code.angularjs.org/1.2.0-rc.3/angular.js"></script> <script data-require="ng-table@*" data-semver="0.3.1" src="http://bazalt-cms.com/assets/ng-table/0.3.1/ng-table.js"></script> <script data-require="ng-table-export@0.1.0" data-semver="0.1.0" src="http://bazalt-cms.com/assets/ng-table-export/0.1.0/ng-table-export.js"></script> <link data-require="ng-table@*" data-semver="0.3.0" rel="stylesheet" href="http://bazalt-cms.com/assets/ng-table/0.3.0/ng-table.css" /> <link data-require="bootstrap-css@*" data-semver="3.0.0" rel="stylesheet" href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" /> <link rel="stylesheet" href="style.css" /> <script src="script.js"></script> </head> <body ng-app="main" ng-controller="DemoCtrl"> <div ng-controller="DemoCtrl"> <transclude-example> Columns: <label class="checkBox" ng-repeat="column in columns"> <input type="checkBox" ng-model="column.visible" /> {{column.title}} </label> <table ng-table="tableParams" show-filter="true" class="table"> <thead> <tr> <th ng-repeat="column in columns" ng-show="column.visible" class="text-center sortable" ng-class="{ 'sort-asc': tableParams.isSortBy(column.field,'asc'),'sort-desc': tableParams.isSortBy(column.field,'desc') }" ng-click="tableParams.sorting(column.field,tableParams.isSortBy(column.field,'asc') ? 'desc' : 'asc')"> {{column.title}} </th> <!--<th>Columns:{{columns.length}}</th>--> </tr> </thead> <tbody> <tr ng-repeat="user in $data"> <td ng-repeat="column in columns" ng-show="column.visible" sortable="column.field"> {{user[column.field]}} </td> </tr> </tbody> </table> </transclude-example> </body> </html>
的script.js
var app = angular.module('main',['ngTable']). controller('DemoCtrl',function($scope,$filter,ngTableParams) { var data = [{name: "Moroni",age: 50},{name: "Tiancum",age: 43},{name: "Jacob",age: 27},{name: "Nephi",age: 29},{name: "Enos",age: 34},age: 34}]; $scope.columns = [ { title: 'Name',field: 'name',visible: true,filter: { 'name': 'text' } },{ title: 'Age',field: 'age',visible: true } ]; $scope.tableParams = new ngTableParams({ page: 1,// show first page count: 10,// count per page filter: { name: 'M' // initial filter } },{ total: data.length,// length of data getData: function($defer,params) { // use build-in angular filter var orderedData = params.sorting() ? $filter('orderBy')(data,params.orderBy()) : data; $defer.resolve(orderedData.slice((params.page() - 1) * params.count(),params.page() * params.count())); } }); var originalData = [{name: "Moroni",age: 34}]; $scope.originalColumns = [ { title: 'Name',visible: true } ]; $scope.originalTableParams = new ngTableParams({ page: 1,{ total: originalData.length,params) { // use build-in angular filter var orderedData = params.sorting() ? $filter('orderBy')(originalData,params.orderBy()) : originalData; $defer.resolve(orderedData.slice((params.page() - 1) * params.count(),params.page() * params.count())); } }); }); app.directive('transcludeExample',function() { return { restrict: 'EA',template: '<div ><div><strong>Transcluded Example</strong></div><div ng-transclude></div></div>',replace: true,transclude: true }; });
有人遇到过同样的问题吗?
定义标头的模板,并设置ng-table的模板标题属性.
原文链接:https://www.f2er.com/angularjs/143791.html你可以看到代码
http://plnkr.co/edit/EXVkjabwfjCreNZAY1c2?p=preview
定义模板标题
<script id="sample_ng_header" type="text/ng-template"> <tr> <th ng-repeat="column in columns" ng-show="column.visible" class="text-center sortable" ng-class="{ 'sort-asc': tableParams.isSortBy(column.field,'desc') }" ng-click="tableParams.sorting(column.field,'asc') ? 'desc' : 'asc')"> {{column.title}} </th> <!--<th>Columns:{{columns.length}}</th>--> </tr> </script>
使用模板设置ng-table的template-header属性
<table ng-table="tableParams" template-header="sample_ng_header" show-filter="true" class="table"> <tbody> <tr ng-repeat="user in $data"> <td ng-repeat="column in columns" ng-show="column.visible" sortable="column.field"> {{user[column.field]}} </td> </tr> </tbody> </table>