我有一个问题,我整晚都试图解决,但我没有找到任何信息,希望你能帮助我。
我在ajax中有一个函数返回php数组中所有用户的纬度和经度,它操作很酷,但是我需要将这些数据包含在另一个函数中,该函数计算主要坐标与所有返回的距离来自银行的坐标
这个功能也运行得很好,我的问题是我需要取这些值并进行比较以查看哪个是最短距离但是当我尝试仅检索最低值时它返回所有已计算的值
它在我的控制台中返回这些数字
用于计算数据库中2个注册用户的纬度和经度的距离
0.38103420280036954 1.1341204506826572
但他们应该只返回0.38103420280036954数字是该函数的最小数量。
我不知道该怎么办我整晚都在寻找并尝试没有成功。
这是我的javascript代码
$.ajax({
type : 'POST',
data : formula,
url : 'http://10.0.0.119/melleve/statusorig2.php',
success : function(data){
var retorno = JSON.parse(data);
$.each(retorno, function (index, value) {
var latitude = value.latitude;
var longitude = value.longitude;
var lat1 = -22.8650697;
var lat2 = latitude;
var long1 = -43.287510499999996;
var long2 = longitude;
var radlat1 = Math.PI * lat1/180;
var radlat2 = Math.PI * lat2/180;
var theta = long1 - long2;
var radtheta = Math.PI * theta/180;
var dist = Math.sin(radlat1)*Math.sin(radlat2) + Math.cos(radlat1) * Math.cos(radlat2) * Math.cos(radtheta);
dist = Math.acos(dist);
dist = dist * 180/Math.PI;
dist = dist * 60 * 1.1515;
var finaldist = dist * 1.609344;
var numeros = [finaldist];
var ok = Math.min.apply(Math, numeros);
console.log(ok);
});
},
error: function(jqXHR, textStatus, errorThrown){
//debugger;
}
//,complete: function(jqXHR, textStatus){
// debugger;
//}
})
这是我的php
$carmodel = $_POST['carmodel'];
$sql = "SELECT * FROM cadast_moto WHERE carmodel = '$carmodel'";
$result = $conn->query($sql);
$encode = array();
while ($res = $result->fetch_array()) {
$arr = array('idmoto' => $res['idmoto'], 'nomemoto' => $res['nomemoto'], 'latitude' => $res['latitude'], 'longitude' => $res['longitude']);
$encode[] = $arr;
//echo (json_encode($arr));
}
答案 0 :(得分:3)
您在$.each
内打印最小值,这意味着它将被多次调用。此外,您的数组只包含一个元素numeros = [finaldist]
。你可能想要这样的东西:
var distances = $.map(arrayOfValues, function(value) {
/* do calcualation for one longitude latitude pair */
return finaldist;
});
var smallestNumber = Math.min.apply(Math, distances);
如果您不熟悉jQuery.map,可以阅读here。