我有一個控制器駐留在名爲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