我在Angular中有一个HTTP请求,它从Mysql表中提取所有数据。
$http({
method: "POST",
url: "framework/actions/league.php?query=getDivision"
}).success(function(data){
$scope.division = data;
});
数据片段如下:
[
{
name: "Someone",
number: "4",
game1: "6",
game2: "2",
score: "8"
},
{
name: "Someone else",
number: "7",
game1: "7",
game2: "3",
score: "10"
},
]
当数据从HTTP请求返回并被分配给$scope.division
时,这些数字被视为字符串,这给我在ngRepeat
中使用orderBy
带来了问题。
如何在不必声明forEach
中的每个字段并使用parseInt()
的情况下将数字字段视为数字?在PHP中可以做到这一点吗?如果没有,那么在Angular javascript中进行操作就可以了。
当然,由于名称字段,我不能将每个字段都视为数字。
在发送结果之前,您可以使用PHP函数intval()
将字符串转换为数字:
$string = '123';
$number = intval($string);
// 123
$number2 = intval('456');
// 456
或者在assign语句上直接强制转换变量:
$string = '123';
$number = (int)$string;
// 123
$number2 = (int)'456';
// 456
或者在AngularJS中使用transformResponse
方法进行操作:
$http({
method: "POST",
url: "framework/actions/league.php?query=getDivision",
transformResponse: function(data) {
for (var i=0; i<data.length; i++) {
for(var k in data[i]) {
if (data[i].hasOwnProperty(k)) {
data[i][k] = isNaN(+data[i][k]) ? data[i][k] : +data[i][k];
}
}
}
return data;
},
success: function(data){
$scope.division = data;
}
});