MOUSEOVER在拼接的HTML无效处理

本文介绍了如何通过jQuery的delegate方法解决在动态加载HTML内容后,原有鼠标移入移出事件失效的问题。原来的代码直接绑定在元素上,导致新增元素无法响应事件。修正方案是在document级别上使用delegate,确保对后来添加的DOM元素也有效。这种方法适用于先加载HTML再绑定JavaScript的场景。
摘要由CSDN通过智能技术生成

正常情况下:

//鼠标移入移出(顶部企业图标信息)
            $(".patternBg").mouseover(function (){  
                $(".enterpriseContent").show();   
            }).mouseout(function () {
                $(".enterpriseContent").hide();
            });

修改成:

复制代码

//鼠标移入移出(顶部企业图标信息)
            $(document).delegate(".patternBg","mouseover",function(){
                var forkIndex = $(this).index();
                $('.enterpriseContent').eq(forkIndex).css("display","block");
            });
            $(document).delegate(".patternBg","mouseout",function(){
                var forkIndex = $(this).index();
                $('.enterpriseContent').eq(forkIndex).css("display","none");
            });

复制代码

 

备注原因:

JQ拼接显示的页面中鼠标事件失效

由于是先加载html在用js层绑定的所有后来加进来的html内容就不再绑定js了

所以我们需要利用delegate绑定,但是同样道理也不能写在普通的方法层里,因为这样还是会失效

所以本身拼接的时候我们就在componentDidMount()里我们就继续在尾部添加我们的delegate()

原文地址:https://www.cnblogs.com/RikuBlog/p/9530874.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要通过mouseover事件判断是否在Polyline内部,可以结合使用高德地图的AMap.GeometryUtil.isPointInRing()方法和Polyline的mouseover事件。 具体实现步骤如下: 1. 监听Polyline的mouseover事件。 2. 在mouseover事件中获取当前鼠标所在的点坐标。 3. 创建一个数组,将Polyline的所有点坐标的经纬度信息存入该数组。 4. 使用AMap.GeometryUtil.isPointInRing()方法来判断当前鼠标所在的点是否在Polyline的内部区域。 示例代码如下: ```javascript var polyline = new AMap.Polyline({ path: [...], // Polyline的所有点坐标 strokeColor: '#3366FF', strokeWeight: 5, strokeStyle: 'solid' }); // 监听Polyline的mouseover事件 polyline.on('mouseover', function(e) { var point = e.lnglat; // 获取当前鼠标所在的点坐标 var path = polyline.getPath(); // 获取Polyline的所有点坐标 // 将Polyline的所有点坐标的经纬度信息存入数组 var pathArray = []; for (var i = 0; i < path.length; i++) { pathArray.push([path[i].lng, path[i].lat]); } // 判断当前鼠标所在的点是否在Polyline的内部区域 var isInside = AMap.GeometryUtil.isPointInRing([point.lng, point.lat], pathArray); if (isInside) { // 鼠标在Polyline内部 console.log('Inside'); } else { // 鼠标在Polyline外部 console.log('Outside'); } }); ``` 需要注意的是,在Polyline的mouseover事件中,获取鼠标所在的点坐标可以使用e.lnglat属性。而判断鼠标所在点是否在Polyline内部的方法和上一题是一样的,都是使用AMap.GeometryUtil.isPointInRing()方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值