jQuery onclick未获得正确的值

jQuery onclick not getting proper values

本文关键字:onclick jQuery      更新时间:2023-09-26

我正在尝试在单击事件中获取图像 ALT 值,但它无法正常工作,并且在单击时显示相同的值(图像 ALT)。

这是代码:

.HTML:

<a href="//cdn.shopify.com/s/files/1/0720/9527/products/MDM02-south-east-postcode-district-map-detail-large_ee8e2826-b33b-4c77-83b2-f162df33ec33_large.gif?v=1420644155" class="product-photo-thumb" title="Map 1">
    <img id="imgVariants" src="//cdn.shopify.com/s/files/1/0720/9527/products/MDM02-south-east-postcode-district-map-detail-large_ee8e2826-b33b-4c77-83b2-f162df33ec33_compact.gif?v=1420644155" alt="Map 1">
</a>
<a href="//cdn.shopify.com/s/files/1/0720/9527/products/png_large.png?v=1420644163" class="product-photo-thumb" title="Map 2">
    <img id="imgVariants" src="//cdn.shopify.com/s/files/1/0720/9527/products/png_compact.png?v=1420644163" alt="Map 2">
</a>

Javascript/jQuery

$(document).ready(function(){
    $('.product-photo-thumb').on("click", function (e) {
      e.preventDefault();
      alert(document.getElementById("imgVariants").alt);
    });
});

>> js小提琴链接

我错过了什么吗?


PS:我知道ID必须是唯一的,但我想要一个即使没有唯一ID也可以工作的解决方案。

有两个元素带有same Id(不应该),删除它们,你应该使用类似 e.target

这是一个工作示例.. http://jsfiddle.net/83cyuozz/1/

   $(document).ready(function(){
        $('.product-photo-thumb').on("click", function (e) {
          e.preventDefault();
          alert(e.target.alt);
        });
      });

试试这段代码

$(document).ready(function(){
    $('.product-photo-thumb').on("click", function (e) {
      e.preventDefault();
      alert($(this).find('img').attr('alt'));
    });
});

演示

注意 ID必须是唯一的。

这是一个工作示例,其中可以有多个具有相同 ID 的元素,但它可以正常工作: JSFIDDLE

  $(document).ready(function(){
    $("body").on("click",".product-photo-thumb", function (e) {
      e.preventDefault();
      alert($(this).children("img").attr("alt"));
    });
  });