我们假设js中一个数组有每个地点的经纬度,我们制定一个地点的经纬度,来对数组中的与这个点的距离长短进行排序,可以使用以下步骤:
1、计算每个地点到目标点的距离。
2、创建一个包含地点和对应距离的对象数组。
3、使用比较函数对这个对象数组进行排序。
4、提取排序后的地点数组。
以下是一个示例代码,演示如何在JavaScript中实现这个过程:
// 计算两点之间的距离(使用经纬度) function calculateDistance(lat1, lon1, lat2, lon2) { const R = 6371; // 地球平均半径(单位:千米) const dLat = (lat2 - lat1) * (Math.PI / 180); const dLon = (lon2 - lon1) * (Math.PI / 180); const a = Math.sin(dLat / 2) * Math.sin(dLat / 2) + Math.cos(lat1 * (Math.PI / 180)) * Math.cos(lat2 * (Math.PI / 180)) * Math.sin(dLon / 2) * Math.sin(dLon / 2); const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)); const distance = R * c; // 距离(单位:千米) return distance; } // 目标点的经纬度 const targetLat = 52.5200; // 目标点的纬度 const targetLon = 13.4050; // 目标点的经度 // 包含每个地点经纬度的数组 const locations = [ { name: "地点 A", lat: 52.5300, lon: 13.4050 }, { name: "地点 B", lat: 52.5400, lon: 13.4150 }, { name: "地点 C", lat: 52.5100, lon: 13.3950 }, // 添加更多地点 ]; // 计算每个地点到目标点的距离,并创建对象数组 const distances = locations.map(location => { const distance = calculateDistance(targetLat, targetLon, location.lat, location.lon); return { name: location.name, distance: distance }; }); // 根据距离排序对象数组 distances.sort((a, b) => a.distance - b.distance); // 提取排序后的地点数组 const sortedLocations = distances.map(item => item.name); console.log(sortedLocations);这段代码首先定义了一个calculateDistance函数来计算两个经纬度之间的距离。然后,它计算每个地点到目标点的距离,并创建了一个包含地点名称和距离的对象数组。最后,它使用sort方法根据距离对对象数组进行排序,然后提取排序后的地点数组。
请确保替换示例中的地点和目标点的经纬度,并根据您的需求进行修改。
网友回复
如何编写一个chrome插件实现多线程高速下载大文件?
cdn版本的vue在网页中出现typeerror错误无法找到错误代码位置怎么办?
pywebview能否使用webrtc远程控制共享桌面和摄像头?
pywebview6.0如何让窗体接受拖拽文件获取真实的文件路径?
如何在linux系统中同时能安装运行apk的安卓应用?
python有没有离线验证码识别ocr库?
各家的ai图生视频及文生视频的api价格谁最便宜?
openai、gemini、qwen3-vl、Doubao-Seed-1.6在ui截图视觉定位这款哪家更强更准?
如何在linux上创建一个沙箱隔离的目录让python使用?
pywebview如何使用浏览器自带语音识别与webspeech 的api?