1.獲取當前定位
getLocal() {
var that = this
uni.getLocation({
type: 'wgs84',
success: function (res) {
// 獲取到經緯度後,調用 computeDistance對數組進行排序
that.computeDistance(res.latitude,res.longitude)
}
)}
},
2.計算距離然後排序
(1)百度到其他大神的計算兩個經緯度距離的方法
/**
* js獲取兩個經緯度之間的距離
* @param lat1 第一點的緯度
* @param lng1 第一點的經度
* @param lat2 第二點的緯度
* @param lng2 第二點的經度
* @returns {Number}
*/
distance(la1, lo1, la2, lo2) {
var La1 = la1 * Math.PI / 180.0;
var La2 = la2 * Math.PI / 180.0;
var La3 = La1 - La2;
var Lb3 = lo1 * Math.PI / 180.0 - lo2 * Math.PI / 180.0;
var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(La3 / 2), 2) + Math.cos(La1) * Math.cos(La2) * Math.pow(Math.sin(Lb3 / 2), 2)));
s = s * 6378.137;
s = Math.round(s * 10000) / 10000;
s = s.toFixed(2);
return s;
},
(2) 調用接口獲取到醫院的列表,然後取得每個醫院的經緯度與用戶當前定位的經緯度進行計算
computeDistance(latitude,longitude) {
var that = this
// 獲取醫院列表
uni.request({
url: app.apiUrl + 'small/index/index',
success: (res) => {
that.poslist = res.data.poslist
// 計算醫院列表中經緯度與當前的距離,並添加distance屬性到數組的元素中 key:distance vaule: 距離
for (let i=0; i<that.poslist.length; i++) {
// 調用distance的方法計算兩點的距離,並把距離值賦值給醫院數組對象中的新屬性distance
that.poslist[i].distance = (that.distance(latitude,longitude,that.poslist[i].latitude,that.poslist[i].longitude))
// 根據新屬性值distance對數組重新排序,距離最短排前面
that.poslist.sort(function(a,b){
return a.distance-b.distance;
})
}
}
})
},