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

问题:

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

原理:

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

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <script src="https://cdn.bootcss.com/jquery/3.4.0/jquery.min.js"></script>
    <script src="https://cdn.bootcss.com/vConsole/3.3.0/vconsole.min.js"></script>
    <!-- <script>var vConsole = new VConsole();</script> -->
    <title>Document</title>
</head>

<body>


    <div id="sch-box" class="sch-box">
        <div class="sch-input-cont">

            <input id="searchText" class="borderradius-3 sch-input" type="search" placeholder="请输入您车所在的位置">

            <span id="schInputDel"></span>
        </div>
    </div>
    <div id="login_address">
        <a class="address-search" id="address-search" href="javascript:;">
            <span class="address-searchfont">
                点击定位当前位置
            </span>
        </a>
    </div>
    <div id="searchResultPanel" style="border:1px solid #C0C0C0;width:150px;height:auto; display:none;"></div>
    <div id="allmap"></div>

    <script type="text/javascript"
        src="https://api.map.baidu.com/api?v=2.0&ak=wrQtcxmVhln7DH3Ozx8RRK1xreYVIaT2"></script>
    <!--加载鼠标绘制工具-->

    <script type="text/javascript">
        var map;
        var geoc = new BMap.Geocoder();
        var myValue;
        $(function () {
            var p = { x1: 0, y1: 0, x2: 0, y2: 0 };
            $(".footers").hide();
            $("html").css("background-color", "#f5f5f5");

            var height = $(window).height() - 146;
            $("#allmap").css("height", height + 'px');

            map = new BMap.Map("allmap");
            var point = new BMap.Point(116.331398, 39.897445);
            map.centerAndZoom(point, 14);
            map.enableScrollWheelZoom(true);     //开启鼠标滚轮缩放
            
//主要内容 S
            map.addEventListener('touchstart', function (evt) {
                // console.log(evt)
                console.log('X:', evt.touches[0].clientX)
                p.x1 = p.x2 = evt.touches[0].clientX;
                console.log('Y:', evt.touches[0].clientY)
                p.y1 = p.y2 = evt.touches[0].clientY;
            })
            map.addEventListener('touchmove', function (evt) {
                console.log('X:', evt.touches[0].clientX)
                p.x2 = evt.touches[0].clientX;
                console.log('Y:', evt.touches[0].clientY)
                p.y2 = evt.touches[0].clientY;
            })
            map.addEventListener('touchend', function (evt) {
                //如果x轴或者y轴移动超过10px,那么认为是拖动,而不是点击(touch),使用绝对值保证左右上下移动都可以计算正确
                if (Math.abs(p.x1 - p.x2) < 10 || Math.abs(p.y1 - p.y2) < 10) {
                    alert('点击了地图')
                    console.log(p);
                }else{
                    alert('拖动了地图')
                    console.log(p);
                }
            })
//主要内容 E
            map.addEventListener('click', function () { console.log('touch2') })//该事件在部分华为手机无法出发,其他手机暂未发现
        })

    </script>

</body>

</html>

结果:

  1. 移动距离小于10px

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

    image.png
要用Web语言(通常指HTML、CSS和JavaScript)为华为手机制作介绍页面,可以按照以下步骤来设计: 1. **HTML结构**: - 使用HTML5框架创建网页骨架,包括头部(head)、主体(body)等元素。例如: ``` <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8"> <title>华为手机介绍</title> <link rel="stylesheet" href="styles.css"> <!-- 引入样式表 --> </head> <body> <header> <h1>华为手机介绍</h1> </header> <main> <section class="phone-intro"> <!-- 产品图片和信息将放在这里 --> </section> </main> </body> </html> ``` 2. **CSS样式**: - 创建一个名为`styles.css`的文件,添加样式来美化布局和内容。比如字体、颜色、间距和响应式设计,让页面适应不同屏幕尺寸的华为手机。 ``` .phone-intro { /* 样式如:背景颜色、标题样式、内容区域大小等 */ } ``` 3. **JavaScript交互**: - 如果需要动态效果,可以使用JavaScript来控制图片轮播、展示详细规格或者用户交互。例如: ```javascript document.addEventListener('DOMContentLoaded', function() { // 图片轮播或按钮点击事件处理 }); ``` 4. **内容填充**: - 在`<section>`标签内插入华为手机的图片、型号、特色功能、性能指标等文字描述。 5. **响应式设计**: - 通过媒体查询(@media)确保页面在不同华为设备上显示良好,考虑到屏幕尺寸和触控优化。 完成以上步骤后,用户访问该网页就能看到华为手机的简介,并能通过简单的交互获取更多信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值