IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> uniapp 从0到1 h5地图引入定位服务,获取两个经纬度之间的距离或多个经纬度之间的距离,跨域配置 -> 正文阅读

[JavaScript知识库]uniapp 从0到1 h5地图引入定位服务,获取两个经纬度之间的距离或多个经纬度之间的距离,跨域配置

uniapp h5地图必须选择腾讯地图,这是uniapp规定的
1.引入定位服务
首先来到腾讯地图开放平台,申请一个key
在这里插入图片描述
在这里插入图片描述
这是可以多选的,但必须勾选webservice api,如果你报这个问题了,就是没勾选
在这里插入图片描述

接下来就可以用定位功能
			 如果需要具体信息,只能为app端,因为H5只有经纬度
			 https://uniapp.dcloud.io/api/location/location.html#getlocation
 	  uni.getLocation({
          type: 'gcj02',
          geocode: true,
          success: (res) => {
             console.log(res)
          },
          complete: (e) => {
            console.log(e);
          },
          fail: (e) => {
             console.log(e);
          }
     });
下面介绍怎么获取两个点,或者多个点之间距离

点击跳转到腾讯地图api

它这里其实就是发了个网络请求,但是你需要注意的是,如果使用axios,或者uni.request

一定会跨域问题,所以这时候,你就需要使用jsonp,这也是腾讯官网推荐的

推荐使用vue-jsonp

外部数据结构
onLoad() {
 computeDistance([[38.8626430801, 121.5300857178],[38.8626430801, 121.5300857178]]).then((res)=>{
 console.log(res);
 })
 }
//这是一个js内
import { jsonp } from 'vue-jsonp'
export const computeDistance = (...fromList) => {
  return new Promise((resolve, reject) => {
    // 获取当前位置
    uni.getLocation({
      type: 'gcj02',
      geocode: true,
      success: (res) => {
        // 获取位置的经纬度
        const latitude = res.latitude;
        const longitude = res.longitude;
        // 数组降维
        const newFormList = fromList.reduce((previousValue, currentValue) => {
          return previousValue.concat(currentValue)
        }, [])
        getDistanceData([latitude, longitude], newFormList);
      },
      fail: (e) => {
        console.error(e);
      }
    });

    // 判断当前是否是一个可用数组
    function isAvailableArray(arr) {
      return arr && Array.isArray(arr) && arr.length > 0;
    }
    // 数组内部个数不同,拼接的字符串是不同的
    // 来到这里说明一定是一个数组,并且长度一定大于0,可用
    function parmaHandler(from, to) {
      let distanceFrom = undefined;
      let distanceTo = undefined;
      // 起点
      distanceFrom = [...from].toString();
      // 如果外界传递参数只有一个数组
      if (to.length === 1) {
        distanceTo = [...to].toString();
      }
      //  到腾讯地图的时候需要成对出现,目前业务起点from只有一个 
      //  数据格式  to 需要多个拼接的字符串,最后一个不需要;
      if (to.length > 1) {
        distanceTo = to.reduce((str, cur, index) => {
          return str += index + 1 === to.length ? cur.toString() : cur.toString() + ';'
        }, '');
      }
      return {
        distanceFrom: distanceFrom,
        distanceTo: distanceTo
      }
    }

    function getDistanceData(from, to) {
      // 距离集合
      let distanceData = [];
      // 没有值,返回
      if (!from || !to) return;
      // 不是一个可用数组,返回
      if (!isAvailableArray(from) || !isAvailableArray(to)) return;
      // 参数处理
      let data = parmaHandler(from, to);
      // 获取距离,当前为测试key
      jsonp('https://apis.map.qq.com/ws/distance/v1/matrix', {
        mode: 'walking',
        from: data.distanceFrom,
        to: data.distanceTo,
        key: '你的key',
        output: 'jsonp'
      }).then((data) => {
        // 不是一个可用的数组返回
        if (!isAvailableArray(data.result.rows)) return;
        const row = data.result.rows;
        // 获取距离
        row.forEach((item) => {
          if (isAvailableArray(item.elements)) {
            distanceData = item.elements.map(item => item.distance);
            resolve(distanceData);
          }
        })
      })
    }
  })
};
最后如果你有更好的方式,可以留言,看到这里了,点个赞吧!!
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-14 23:43:36  更:2022-04-14 23:49:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 0:40:21-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码