我有一个控制器驻留在名为EmployeeCtrl.js
的单独文件中。在此控制器内部,我有一个名为convertJsonDate
的过滤器,可将JsonResult date format
转换为标准格式MM/dd/yyyy hh:mm:ss
。从控制器中的不同JS文件调用过滤器
我现在的问题是,我怎样才能使这个过滤器在未来的不同控制器中可重用?我已经读过,你可以添加你的过滤器在一个单独的js文件filters.js
并注入到你的控制器,但我不知道要实现这一点。
TIA
app.js
(function() {
'use strict';
angular.module('app', []);
})();
EmployeeCtrl.js
(function() {
'use strict';
var app = angular.module('app');
app.filter('convertJsonDate', ['$filter', function ($filter) {
return function (input, format) {
return (input) ? $filter('date')(parseInt(input.substr(6)), format) : '';
};
}]);
app.controller('app.EmployeeController', ['$scope', 'app.EmployeeService', function ($scope, EmployeeService) {
GetAllEmployee();
$scope.sortColumnBy = function (keyname) {
$scope.sortKey = keyname;
$scope.reverse = !$scope.reverse;
}
$scope.employee = {
employeeId: '',
firstName: '',
lastName: '',
password: '',
daysPerWeek: 0,
active: true,
departmentId: 0,
accountTypeId: 0
};
$scope.clear = function() {
$scope.employee.employeeId = '';
$scope.employee.firstName = '';
$scope.employee.lastName = '';
$scope.employee.password = '';
$scope.employee.daysPerWeek = 0;
$scope.employee.active = false;
$scope.employee.departmentId = 0;
$scope.employee.accountTypeId = 0;
};
function GetAllEmployee() {
var getEmployeeData = EmployeeService.getEmployees();
getEmployeeData.then(function (employee) {
$scope.employees = employee.data;
}, function() {
alert('Error in getting employee records');
});
};
}]);
})();
使用convertJsonDate滤波器
<div ng-app="app">
<div ng-controller="app.EmployeeController">
.....
<tbody>
<tr ng-repeat="e in employees | orderBy:sortKey:reverse | filter:searchKeyWord">
<td>{{e.AccountDateExpired | convertJsonDate:'MM/dd/yyyy hh:mm:ss'}}</td>
</tr>
</tbody>
....
</div>
</div>
引擎收录
Index.chtml http://pastebin.com/aXDSmYAV
EmployeeCtrl.js http://pastebin.com/eQhRREPy
app.js http://pastebin.com/1GB4uhvx
过滤器可用于整个项目。一旦制作完成,您可以在任何模板中使用。你是在谈论在控制器中使用它吗? –
将'convertJsonDate'过滤器放置在不同的JS文件中后,我收到此错误'错误:[$ injector:unpr]未知提供者:convertJsonDateFilterProvider < - convertJsonDateFilter'。 我也读过一篇文章,您可以直接在控制器中使用过滤器,而不是在视图中使用它。 – klaydze