RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1514485
Accepted
powerg
powerg
Asked:2023-04-20 01:01:30 +0000 UTC2023-04-20 01:01:30 +0000 UTC 2023-04-20 01:01:30 +0000 UTC

如何在单击按钮时更改图像?

  • 772

当您单击一种颜色时,有必要更改图片。但问题是页面上可能有很多这样的块,并且所有内容都只适用于第一个。你能告诉我如何使每个块都有自己的图片吗?

document.body.addEventListener('click', e => {
  if (!e.target.matches('button')) return
  document.querySelector('.pic img').src = e.target.dataset.src
  
  document.querySelectorAll('button').forEach(btn => btn.classList.remove('active'))
  e.target.classList.add('active')
})
.pic {
  display: inline-block;
}

button {
  padding: 1em;
}

button.active {
  background: tomato;
}
<div class="content">
  <div class="pic">
    <img src="https://image.coolblue.nl/422x390/products/1216241">
  </div>

  <button data-src="https://image.coolblue.nl/422x390/products/1216241" class="active">
    Blue
  </button>

  <button data-src="https://image.coolblue.nl/422x390/products/1214824">
    Black
  </button>
  <div>

    <div class="content">
      <div class="pic">
        <img src="https://image.coolblue.nl/422x390/products/1216241">
      </div>

      <button data-src="https://image.coolblue.nl/422x390/products/1216241" class="active">
        Blue
      </button>

      <button data-src="https://image.coolblue.nl/422x390/products/1214824">
        Black
      </button>
      <div>

javascript
  • 2 2 个回答
  • 38 Views

2 个回答

  • Voted
  1. RAMe0
    2023-04-20T01:47:05Z2023-04-20T01:47:05Z

    副手 2 个选项。

    document第一种是不在我们的父级中,而是在我们的父级中查找图片target。

    e.target.parentElement.querySelector('.pic img').src = e.target.dataset.src
    

    第二种,在我看来,更通用,是将.content ID产品(类型id="item-1")添加到块中,添加到按钮中data-itemid,其中将包含ID其图像需要更改的产品。在这种情况下,更改图像将像这样完成:

    let pic = document.querySelector('#' + e.target.dataset.itemid + ' .pic img')
    pic.src = e.target.dataset.src
    

    第二种选择更通用,因为。与 HTML 结构没有那么紧密的联系。因此,下面的工作示例与他有关。

    附言。不要忘记正确关闭HTML块。在您的示例中,在 y 块的末尾,.content而不是结束标记</div>,开始标记是 -<div>

    document.body.addEventListener('click', e => {
      if (!e.target.matches('button')) return
    
      let pic = document.querySelector('#' + e.target.dataset.itemid + ' .pic img')
      pic.src = e.target.dataset.src
    
    
      document.querySelectorAll('#' + e.target.dataset.itemid + ' button').forEach(btn => btn.classList.remove('active'))
      e.target.classList.add('active')
    })
    .pic {
      display: inline-block;
    }
    
    button {
      padding: 1em;
    }
    
    button.active {
      background: tomato;
    }
    <div class="content" id="item-1">
      <div class="pic">
        <img src="https://image.coolblue.nl/422x390/products/1216241">
      </div>
    
      <button data-src="https://image.coolblue.nl/422x390/products/1216241" class="active" data-itemid="item-1">
        Blue
      </button>
    
      <button data-src="https://image.coolblue.nl/422x390/products/1214824" data-itemid="item-1">
        Black
      </button>
    </div>
    
    <div class="content" id="item-2">
      <div class="pic">
        <img src="https://image.coolblue.nl/422x390/products/1216241">
      </div>
    
      <button data-src="https://image.coolblue.nl/422x390/products/1216241" class="active" data-itemid="item-2">
            Blue
          </button>
    
      <button data-src="https://image.coolblue.nl/422x390/products/1214824" data-itemid="item-2">
            Black
          </button>
    </div>

    • 1
  2. Best Answer
    Oliver Patterson
    2023-04-20T05:10:49Z2023-04-20T05:10:49Z

    我会建议这个选项。在其中,您监听任何点击(理想情况下,您需要在包装这些块的容器上挂一个监听器),检查被点击的元素是一个按钮,并以 、图像和活动按钮document的形式获取我们的包装器。.content我们从活动按钮中删除类,将其提供给按下的按钮并从按钮属性中active设置- 。image srcdata-src

    document.addEventListener("click", ({target}) =>
    {
      if (target.tagName !== "BUTTON")
      {
        return;
      }
      
      const wrapper = target.closest(".content");
      if (wrapper === null)
      {
        return;
      }
      
      const image = wrapper.querySelector(".pic img");
      const activeButton = wrapper.querySelector("button.active");
      if (image === null || activeButton === null)
      {
        return;
      }
      
      activeButton.classList.remove("active");
      
      const button = target;
      button.classList.add("active");
      
      image.src = button.dataset.src; 
    });
    .pic {
      display: inline-block;
    }
    
    button {
      padding: 1em;
    }
    
    button.active {
      background: tomato;
    }
    <div class="content">
      <div class="pic">
        <img src="https://image.coolblue.nl/422x390/products/1216241">
      </div>
    
      <button data-src="https://image.coolblue.nl/422x390/products/1216241" class="active">
        Blue
      </button>
    
      <button data-src="https://image.coolblue.nl/422x390/products/1214824">
        Black
      </button>
    </div>
    
    <div class="content">
      <div class="pic">
        <img src="https://image.coolblue.nl/422x390/products/1216241">
      </div>
    
      <button data-src="https://image.coolblue.nl/422x390/products/1216241" class="active">
            Blue
      </button>
    
      <button data-src="https://image.coolblue.nl/422x390/products/1214824">
            Black
      </button>
    </div>

    • 1

相关问题

  • 第二个 Instagram 按钮的 CSS 属性

  • 由于模糊,内容不可见

  • 弹出队列。消息显示不正确

  • 是否可以在 for 循环中插入提示?

  • 如何将 JSON 请求中的信息输出到数据表 Vuetify vue.js?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5