簡體   English   中英

復選框上的表單更改事件單擊

[英]Form change event on checkbox click

我真的不明白這是什么問題。 我想要單擊表單中的復選框以獲取最接近的“ h2”並獲取其文本。

HTML

<form action="" method="get" id="productFilterForm">
  <h2 class="attribute-name">Brands</h2>
  <div class="option">
      <label>
          <input type="checkbox" name="Royal Canin" value="163">Royal Canin
      </label>
  </div>
  <div class="option">
      <label>
          <input type="checkbox" name="Brit" value="164">Brit
      </label>
  </div>
  <div class="option">
      <label>
          <input type="checkbox" name="Purina Pro Plan" value="165">Purina Pro Plan
      </label>
  </div>
</form>

JavaScript的

$(document).ready(function(){
   $('#productFilterForm').on('change', 'input:checkbox', function () {
    let text = $(this).closest("h2").html(); <---- UNDEFINED
    //let text = $(this).find("h2").html(); <---- UNDEFINED
    console.log(text);
   }
});

我嘗試了許多事情和方法,只是找不到從“輸入”到DOM樹的任何元素。

試試這個代碼

$('#productFilterForm').on('change', function () {
let text = $(this).find("h2").html();
console.log(text);   
})

我找到了解決方案:

$(document).ready(function(){
   $('#productFilterForm input:checkbox').on('change', function () {
      let text = $(this).closest('div.option').prevAll('h2.attribute-name').html();
      console.log(text);
   }
});

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM