jQuery:如何挂钩和识别下拉选择

问题描述

我有一个包含选择的行列表:

<ul>
  {% for select in selects %}
    <li>
      <select id="select-{{ select.id }}">
        <option selected disabled>Select value...</option>
        {% for value in values %}
          <option value="{{ value.id }}">{{ value.name }}</option>
        {% endfor %}
      </select>
    </li>
  {% endfor %}
</ul>

我想要统一的 jQuery 代码,例如:

$(something).onSelect(function(value) {
  // use this.id as select id;
  // use value as selected value;
  return false; // don't change selected item,leave it as 'Select value...'
}

解决方法

您可以在选择器中使用 * 这会选择具有指定属性的所有元素,其值包含给定的子字符串,然后只需使用 attr('id')).val() 从选择中获取值-框。

演示代码

$("select[id*='select']").on("change",function(value) {
  console.log($(this).attr('id')) //get id
  console.log($(this).val()) //get value
  //some condition 
  //to set first value
  //$(this).val('Select value...') //or
  //$("#"+$(this).attr('id')).val('Select value...')
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<ul>

  <li>
    <select id="select-1">
      <option selected disabled>Select value...</option>
      <option value="1">1</option>
      <option value="2">2</option>
    </select>
  </li>
  <li>
    <select id="select-2">
      <option selected disabled>Select value...</option>
      <option value="1">1</option>
      <option value="2">2</option>

    </select>
  </li>
  <li>
    <select id="select-3">
      <option selected disabled>Select value...</option>
      <option value="1">1</option>
      <option value="2">2</option>

    </select>
  </li>

</ul>