您的位置:首页技术文章
文章详情页

angular.js - 在ng-option 里使用过滤器无效

【字号: 日期:2024-09-14 09:15:58浏览:30作者:猪猪

问题描述

想在ng-option 把英文转为中文显示,但是filter貌似无效。我使用了uppercase也是无效。为什么?我看网上很多都这样写的呀

下面是代码:(1)controller里定义了状态列表:

$scope.allStatuses = ['all', 'process', 'resolve', 'finish', 'invalid'];

(2)html里初始化下拉列表,想用 myStatusFilter 这个filter格式化为中文显示

<select ng-model='status' ng-options='status for status in allStatuses | myStatusFilter'> </select>

(3) filter实现

angular.module('itil.mine').filter(’myStatusFilter’, myStatusFilter); function myStatusFilter() {return function (input) { var output; switch (input) {case ’process’: output = '处理中'; break;case ’resolve’: output = '已解决为落实'; break;case ’finish’: output = '已解决已落实'; break;case ’invalid’: output = ’无效’; break;case ’all’: output = '所有'; break; } return output;} } "

问题解答

回答1:

angular.js - 在ng-option 里使用过滤器无效

你调试一下过滤器的代码就知道问题了,你的参数你以为是对象其实是数组,所以switch没有匹配到值,直接return出去了一个undefined。

相关文章: