AngularJS 用の最初のカスタム フィルターを作成しようとしています。何かが文字列か数値かを識別する機能が必要です。数値の場合は、組み込みの filter を使用してそのようにフォーマットします| number
。
現在、次を使用した回避策があり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>
コントローラ:
$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 を使用して手動でフィルタを実行する必要がありますか?