H5定位终极解决方案

发布时间:2020-09-02 21:22:21 作者:qq5dda6ecead5a8
来源:网络 阅读:166

H5定位终极解决方案
背景
做一个H5的微商城,主要在微信内,但也要考虑到其他浏览器。其中,首页需要根据当前用户的经纬度找到距离最近的门店并展示。前端需要做的工作就是获取用户的经纬度然后查询后台接口并渲染页面。

目标与分析
我们的目标是经过封装之后,只需要调用一个方法就可以拿到返回的位置信息。
我们需要做的事情是,针对不同的端(微信H5和其他浏览器环境)封装不同的类,再通过一个方法通过 UA 区分,调用不同环境对应的类获取位置。
在微信内部,经过反复的实践之后,不论是通过原生的 HTML5 定位,还是通过第三方(如百度或腾讯地图) jsapi 获取位置,不仅定位时间长,甚至经常出现定位失败的情况,严重影响用户体验,尤其对于大部分信息流都依赖于用于位置的商城首页来说,是完全无法接受的。所以在微信内我们只有微信 sdk 这一种选择;

而对于浏览器端,通过第三方的地图 jsapi 或定位组件,可以稳定且较快速地获取位置信息,为了与微信内尽量保持一致,我们选择的是腾讯地图 jsapi。

解决方案
Talk is cheap, show me the code. 废话不多说,直接上代码:

  1. 在浏览器中,通过腾讯地图jsapi获取位置
    1.1 在项目的 html 模版文件中引入腾讯地图 jsapi
    <!-- index.html -->
    <script charset="utf-8" src="https://map.qq.com/api/js?v=2.exp&key=腾讯地图key&referer=应用名称"></script>
    说明:

使用腾讯地图 jsapi, 需要先去腾讯地图开放平台申请自己的账号,然后创建自己的应用,将腾讯地图key 和创建的应用名称替换上面的值。

1.2 调用获取位置接口,获取位置信息
为了方便复用,我们单独封装一个腾讯地图 jsapi 的类,命名为 tMap.js

// tMap.js
const qq = window.qq
var geolocation = null
if (qq && qq.maps) {
// 初始化定位组件
geolocation = new qq.maps.Geolocation(
'QVLBZ-YUULR-OUMW7-WKXFD-4SUWS-UDBIA',
'mymap'
)
}

class TMap {
// 获取定位计数器 用于定位失败时累计次数 超过3次后不再继续,抛出定位失败错误
getPositionCount = 0

// 对外暴露的获取位置接口
getLocation () {
return new Promise((resolve, reject) => {
// 定位成功回调
this.getTMapLocation(resolve, reject)
})
}

// 调用腾讯地图获取位置
getTMapLocation (success, fail) {
const _self = this

// 定位成功回调
const showPosition = position => {
  uni.setStorage({
    key: 'positionData',
    data: position
  })
  success(position)
}

// 定位失败回调
const showErr = (err) => 
  // 如果获取定位失败超过3次 抛出错误 否则继续获取定位信息
  if (this.getPositionCount > 3) {
    fail('超过3次 获取定位失败')
  } else {
    // 定位失败递归
    _self.getPositionCount = _self.getPositionCount + 1
    _self.getTMapLocation(success, fail)
  }
}

// 调用腾讯web定位组件获取位置信息
if (geolocation) {
  geolocation.getIpLocation(showPosition, showErr, {
    timeout: 6000,  // 定位超时时长 单位ms
    failTipFlag: true
  })
}

}
}

export default new TMap()

  1. 在微信 webview 中, 通过微信sdk获取位置信息
    2.1 微信 js-sdk 相关的准备工作
    2.1.1 引入js文件
    /**
    • 微信sdk异步加载
    • @param {*} src
    • @param {} callback api接口
      /
      export const handlerLoadScript = callback => {
      const src = https://res.wx.qq.com/open/js/jweixin-1.4.0.js
      if (!(typeof callback === 'function')) {
      callback = function() {}
      }
      var check = document.querySelectorAll(script[src="${src}"])
      if (check.length > 0) {
      check[0].addEventListener('load', function() {
      callback()
      })
      callback()
      return
      }
      var script = document.createElement('script')
      var head = document.getElementsByTagName('head')[0]
      script.type = 'text/javascript'
      script.charset = 'UTF-8'
      script.src = src
      if (script.addEventListener) {
      script.addEventListener(
      'load',
      function() {
      callback()
      },
      false
      )
      } else if (script.attachEvent) {
      script.attachEvent('onreadystatechange', function() {
      var target = window.event.srcElement
      if (target.readyState === 'loaded') {
      callback()
      }
      })
      }
      head.appendChild(script)
      }
      2.1.2 注入权限验证配置
      所有需要使用JS-SDK的页面必须先注入配置信息,否则将无法调用。通常是通过后台接口获取配置信息。

/**

/**

/**

/**

export default getLocation

  1. 页面调用
    3.1 绑定方法到 Vue 原型上
    import getLocation from '@/module/utils/getLocation'
    Vue.prototype.$getLocation = getLocation
    3.2 在页面组件中调用
    onShow() {
    // 获取位置信息后请求后台接口
    this.$getLocation()
    .then(res => {
    console.warn('首页获取位置成功', res)
    this.latitude = res.lat
    this.longitude = res.lng
    // 这里根据获取到的经纬度请求后台接口...
    })
    .catch(err => {
    console.error('首页获取位置失败', err)
    // 错误处理
    })
    }

总结
遇到的坑以及需要注意的点:

使用微信sdk获取位置信息需要按顺序完成以下步骤:
异步加载微信sdk
通过接口获取配置信息,配置微信sdk
在wx.ready回调中调用方法
必须严格按顺序完成以上的三个步骤,否则是无法调用微信sdk的功能的。

总之,通过这篇文章,可以解决 H5 定位 99% 以上的应用场景。

推荐阅读:
  1. Oracle DISPLAY COLOR终极解决方案
  2. python vscode import unsolved import 终极解决方案

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:[js高手之路]图解javascript的原型(prototype)对象,原型链实例

下一篇:Cacti不出图dd

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》