加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

如何在DOM加载后引用动态添加的元素而无需对任何事件进行操作?

发布时间:2020-12-14 23:21:40 所属栏目:资源 来源:网络整理
导读:我知道 JQuery提供了.on和.live(已弃用),但是这些假设您希望将事件处理程序附加到动态添加元素的一个或多个事件中,而我不这样做.我只需要引用它,这样我就可以访问它的一些属性. 更具体地说,有这样的多个动态元素都设置了class =“cluster”,并且每个动态元素
我知道 JQuery提供了.on和.live(已弃用),但是这些假设您希望将事件处理程序附加到动态添加元素的一个或多个事件中,而我不这样做.我只需要引用它,这样我就可以访问它的一些属性.

更具体地说,有这样的多个动态元素都设置了class =“cluster”,并且每个动态元素都有:title属性,top属性和left属性的不同值.

这些jquery选项都不起作用:

var allClusters = $('.cluster');
var allClusters2 = $('#map').children('.cluster');
var allClusters3 = $('#map').find('.cluster');

同样,我不想附加任何事件处理程序,所以.on似乎不是正确的解决方案,即使我要劫持它,添加一个虚假事件,一个doNothing处理程序,然后只是引用我的属性.
必须有一个更好的解决方案.有任何想法吗?

更新:
我错误地说了标题,因为我的意思是说元素是动态添加到DOM的,而不是通过JQuery.标题已更新.

解决方法

我想到了.元素没有显示,因为DOM还没有更新.

我正在使用Google Maps和MarkerClustererPlus来提供更多上下文,当我使用markerclustererplus添加地图标记时,它们在添加后的javascript代码中不可用.

将google maps event listener添加到我的谷歌地图修复了问题:

google.maps.event.addListener(myMarkerClusterer,'clusteringend',function () {
    // access newly added DOM elements here
});

一旦我添加了该侦听器,所有上述JQuery选择器和/或方法都可以正常工作:

var allClusters = $('.cluster');
var allClusters3 = $('#map').find('.cluster');

虽然这个没有,但那是因为它只找到了父母的直接后代:

var allClusters2 = $('#map').children('.cluster');

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读