时间:2016-12-23 10:32:44

标签: javascript php onchange

这是我的观点,请看一下:

<div class="form-group target" id="tools" >
  <div class="input-group">
    <div class="col-lg-6"> <select class="form-control" style="width: 100%" name="tool_id[]" id="toolss" onchange="tool(this)" required>
      <option value="">Select</option>

      </select></div>

    <div class="col-lg-3">  
      <input type="text" class="form-control" required name="quantity[]" id="quantity" placeholder="Quantity">
    </div>
    <div class="col-lg-3" id="avail">  
      <p class="available">0 available</p>
    </div>

    <span class="input-group-btn">
      <button type="button" class="btn btn-danger addel-delete"><i class="fa fa-remove"></i>
      </button>
    </span>
  </div>
</div>

这是我的剧本:

function tool(sel)
{
  var tools=sel.value;

  alert(tools);

  var url='<?php echo base_url(); ?>admin/tool/ajax_available';
  $.post(url, {tools:tools}, function(data){  
    alert("Value: " + $(".available").html(data));
  });
}

问题是每当我从选择框中选择相应的值并且所有先前选择的值变得相同时。 图像显示在这里。

Valid XHTML http://spdc.in/demo/spectra/assets/images/s-tool1.PNG

1 个答案:

答案 0 :(得分:1)

<强> Working fiddle

问题:当您使用.available选择器时,它会影响文档中包含available类的所有元素。

建议的解决方案:

id在同一文档中应该是唯一的,因此,如果您有多个tools,则应将id替换为有效结构的类:

<div class="form-group target tools">

然后你应该引用选择器中的当前元素,所以使用:

$(sel).closest('.tools').find('.available').html(data);

希望这有帮助。