当前位置:   article > 正文

百度地图 华为手机 addEventListener click 不兼容解决

map.addeventlistener

问题:

项目中的使用了百度地图,前端在监听点击事件的时候是使用 map.addEventListener('click',function(){...}),苹果手机和小米手机均能出发该事件,但是华为手机确无法出发,或者偶尔用两个手指点击会触发(几率非常小)。后来通过几个博客了解到touch事件(本人后端程序员,对前端不太了解)。

原理:

通过监听touchstarttouchmove两个事件中,x1,y1和x2,y2的差值(绝对),如果大于10px那么认为是拖动,否则认为是点击。
修改后的代码如下,供参考:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  7. <script src="https://cdn.bootcss.com/jquery/3.4.0/jquery.min.js"></script>
  8. <script src="https://cdn.bootcss.com/vConsole/3.3.0/vconsole.min.js"></script>
  9. <!-- <script>var vConsole = new VConsole();</script> -->
  10. <title>Document</title>
  11. </head>
  12. <body>
  13. <div id="sch-box" class="sch-box">
  14. <div class="sch-input-cont">
  15. <input id="searchText" class="borderradius-3 sch-input" type="search" placeholder="请输入您车所在的位置">
  16. <span id="schInputDel"></span>
  17. </div>
  18. </div>
  19. <div id="login_address">
  20. <a class="address-search" id="address-search" href="javascript:;">
  21. <span class="address-searchfont">
  22. 点击定位当前位置
  23. </span>
  24. </a>
  25. </div>
  26. <div id="searchResultPanel" style="border:1px solid #C0C0C0;width:150px;height:auto; display:none;"></div>
  27. <div id="allmap"></div>
  28. <script type="text/javascript"
  29. src="https://api.map.baidu.com/api?v=2.0&ak=wrQtcxmVhln7DH3Ozx8RRK1xreYVIaT2"></script>
  30. <!--加载鼠标绘制工具-->
  31. <script type="text/javascript">
  32. var map;
  33. var geoc = new BMap.Geocoder();
  34. var myValue;
  35. $(function () {
  36. var p = { x1: 0, y1: 0, x2: 0, y2: 0 };
  37. $(".footers").hide();
  38. $("html").css("background-color", "#f5f5f5");
  39. var height = $(window).height() - 146;
  40. $("#allmap").css("height", height + 'px');
  41. map = new BMap.Map("allmap");
  42. var point = new BMap.Point(116.331398, 39.897445);
  43. map.centerAndZoom(point, 14);
  44. map.enableScrollWheelZoom(true); //开启鼠标滚轮缩放
  45. //主要内容 S
  46. map.addEventListener('touchstart', function (evt) {
  47. // console.log(evt)
  48. console.log('X:', evt.touches[0].clientX)
  49. p.x1 = p.x2 = evt.touches[0].clientX;
  50. console.log('Y:', evt.touches[0].clientY)
  51. p.y1 = p.y2 = evt.touches[0].clientY;
  52. })
  53. map.addEventListener('touchmove', function (evt) {
  54. console.log('X:', evt.touches[0].clientX)
  55. p.x2 = evt.touches[0].clientX;
  56. console.log('Y:', evt.touches[0].clientY)
  57. p.y2 = evt.touches[0].clientY;
  58. })
  59. map.addEventListener('touchend', function (evt) {
  60. //如果x轴或者y轴移动超过10px,那么认为是拖动,而不是点击(touch),使用绝对值保证左右上下移动都可以计算正确
  61. if (Math.abs(p.x1 - p.x2) < 10 || Math.abs(p.y1 - p.y2) < 10) {
  62. alert('点击了地图')
  63. console.log(p);
  64. }else{
  65. alert('拖动了地图')
  66. console.log(p);
  67. }
  68. })
  69. //主要内容 E
  70. map.addEventListener('click', function () { console.log('touch2') })//该事件在部分华为手机无法出发,其他手机暂未发现
  71. })
  72. </script>
  73. </body>
  74. </html>

结果:

  1. 移动距离小于10px

    image.png
  2. 移动距离大于10px

    image.png
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/318542
推荐阅读
相关标签
  

闽ICP备14008679号