getElementsBayTagName获取数组foreach遍历报错

文章讲述了在JavaScript中如何处理getElementsByTagName返回的类数组对象,通过使用扩展运算符转换为普通数组以使用forEach方法。同时,文章提到了代码在本地运行成功,但在打包后运行失败的状况,暗示可能涉及到运行环境或依赖的问题。解决方案是通过解构将类数组转换为正常数组。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


需求:获取Editorimg下的img元素数组,通过遍历转换数据。

问题 1:getElementsByTagName获取的是类数组 调用forEach需要转换成Array 数组

问题 2:本地运行成功但打包后它运行时失败

  let EditorDom = document.getElementById('Editorimg');
      // console.log('Editor元素 ==:', EditorDom);
      let imgDom = EditorDom.getElementsByTagName('img');
      console.log('img元素数组 ==:', imgDom);
      // 发图片消息
      if (imgDom.length > 0) {
        console.log('img图片地址 ==:', imgDom[0].src);
        Array.forEach((item) => {
          getImgToBase64(item.src, (data) => {
            let file = dataURLtoFile(data, 'paste');
            this.sendImage(null, file, item.src);
          });
        });
      }

解决方法:

通过解构将类数组转换成正常数组,就可以正常使用forEach遍历了

[...imgDom]


bhttps://mp.youkuaiyun.com/mp_blog/creation/editor?spm=1001.2101.3001.4503

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值