gpt4 book ai didi

javascript - 稍后附加到 DOM 的图像的加载事件

转载 作者:行者123 更新时间:2023-12-02 17:42:46 24 4
gpt4 key购买 nike

我已阅读 jquery: how to listen to the image loaded event of one container div?

我的情况类似:我有一个<body contentEditable="true"/>使用可视化编辑器编辑的标签。该正文的innerHTML 由编辑器修改并触发事件。

问题是我必须处理调整大小逻辑。library中当前的调整大小逻辑是:

    this.$body.on('keyup keydown paste change focus', function() {
return _this.adjustHeight();
});

除了拖放图像时未触发更改事件外,这工作得很好,但幸运的是触发了焦点事件。但是当事件被触发时,图像尚未加载,因此它不会调整到合适的尺寸。

监听最近使用 Js 代码添加到 DOM 的图像加载的最佳方式是什么?我尝试使用 $(window).load(fn)但什么也没捕获。

最佳答案

您可以在添加图像元素时将 adjustmentHeight 函数绑定(bind)到图像元素的加载事件,如下所示;

this.$body.on('keyup keydown paste change focus', function() {
$(this).find('img').off('load', _this.adjustHeight).on('load', _this.adjustHeight);
return _this.adjustHeight();
});
  • $(this)this.$body 相同(但允许您在当前持有者之外提取该函数)。
  • .find('img') 获取 $(this) 内的所有图像元素(因此在可编辑区域内)
  • .off('load', _this.adjustHeight) 从图像元素中删除事件处理程序,如果没有这个,您最终可能会多次绑定(bind)该函数,这也会导致它被调用多次可能很容易成为性能问题
  • .on('load', _this.adjustHeight) 将事件处理程序添加到图像元素,因此当图像加载时会调用该事件处理程序

我想到的是,您可能需要限制 adjustmentHeight 函数不被调用得太频繁,以防止当用户一次拖放大量图像时它卡住您的浏览器(除非它不是这样)我想象它可能是一个昂贵的功能)。但如果这确实是一个问题,您可能还必须使用其他解决方案来解决这个问题。

关于javascript - 稍后附加到 DOM 的图像的加载事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22040614/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com