duanli6618 2017-10-08 16:37
浏览 56
已采纳

Onchange multiple选择如何总结其他输入值中的总和

I have a select option with onchange function that can change the value in other input whenever I click the option.

However it is not working on multiple select which just only show the first select option value only when select many of the option.

HTML select option code

<select class="form-control" onchange="selectFunction(event)" 
name="pay_course[]" required="" multiple>

  <option data-typeid="1111" value="courseId1">courseName1</option>
  <option data-typeid="2222" value="courseId2">courseName2</option>
</select>

Input to be display the total

<input type="number" value="" id="money" class="form-control">

Function script

<script>
function selectFunction(e) {
  var type_id = $('select option:selected').attr('data-typeid'); //to get value
  document.getElementById("money").value =type_id;
}
</script>
  • 写回答

3条回答 默认 最新

  • dongwen9947 2017-10-08 16:45
    关注

    When multiple options are selected then we need to loop through all the selected options and get the data-typeid for each of them using map like:

    function selectFunction(e) {
      var type_id = $('select option:selected').map(function() {
          return $(this).attr('data-typeid');
        })
        .get().map(parseFloat).reduce(function(a, b) {
          return a + b
        });
      console.log(type_id)
      $("#money").val( type_id );
    }
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <select class="form-control" onchange="selectFunction(event)" name="pay_course[]" required="" multiple>
    
      <option data-typeid="1000" value="courseId1">courseName1  </option>
      <option data-typeid="2000" value="courseId2">courseName2  </option>
      <option data-typeid="3000" value="courseId3">courseName3  </option>
      <option data-typeid="4000" value="courseId4">courseName4  </option>
    </select>
    <br/>
    <br/>
    <input type="number" value="" id="money" class="form-control">

    </div>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 52810 尾椎c三个a 写蓝牙地址
  • ¥15 elmos524.33 eeprom的读写问题
  • ¥15 使用Java milo连接Kepserver服务端报错?
  • ¥15 用ADS设计一款的射频功率放大器
  • ¥15 怎么求交点连线的理论解?
  • ¥20 软件开发方法学习来了
  • ¥15 微信小程序商城如何实现多商户收款 平台分润抽成
  • ¥15 HC32L176调试了一个通过TIMER5+DMA驱动WS2812B
  • ¥15 cocos的js代码调用wx.createUseInfoButton问题!
  • ¥15 关于自相关函数法和周期图法实现对随机信号的功率谱估计的matlab程序运行的问题,请各位专家解答!