gpt4 book ai didi

用于文本/数字的 AngularJS 自定义过滤器

转载 作者:行者123 更新时间:2023-12-04 13:16:50 25 4
gpt4 key购买 nike

我正在尝试为 AngularJS 编写我的第一个自定义过滤器。我希望能够识别某事物是字符串还是数字。如果它是一个数字,它会使用内置过滤器 | number 对其进行格式化。 .

我目前have a workaround using ng-if :

HTML

<table>
<tr ng-repeat="(key, val) in data">
<td>{{key}}</td>
<td ng-if="isNumber(val)">{{val | number}}</td>
<td ng-if="!isNumber(val)">{{val}}</td>
</tr>
</table>

Controller :
$scope.data = { 
One:55689,
two:"consider all the options",
three:800243,
four:"all over",
five:"or just beginning"
};

$scope.isNumber = function (value) {
return angular.isNumber(value);
};

我认为将其分配为自己的过滤器会是一个更好的解决方案。这就是我到目前为止所拥有的(是的,我知道这是最基本的......这是我的第一个)。
.filter('textOrNumber',function(){
return function (input) {
if(typeof input === 'number'){
console.log("I'm a number");
//return as formatted number
} else {
console.log("Not a number");
//do nothing, just return
};
return input;
};
})

当它验证为数字时,我可以让它应用 Angular | number筛选?还是我需要自己手动使用 javascript 进行过滤?

最佳答案

我会注入(inject) $filter服务,然后以编程方式调用号码过滤器,如下所示:

angular.module('filters', []).
filter('textOrNumber', ['$filter', function ($filter) {
return function (input, fractionSize) {
if (isNaN(input)) {
return input;
} else {
return $filter('number')(input, fractionSize);
};
};
}]);

这样您就可以使用您的 textOrNumber像这样过滤:
{{myText|textOrNumber:4}}

这是工作 JSFiddle .

关于用于文本/数字的 AngularJS 自定义过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17238661/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com