javascript – 从“Bootstrap-Select”获取价值

我有一个选择框,当我选择该选项时,它会使用选择框的值更新输入框.这适用于旧版本的Bootstrap-Select.但在较新的版本中,它不再起作用了.我正在寻找一种方法,使其在较新的版本中工作.谢谢.

>旧版本(工作):http://jsfiddle.net/u967uwtf/
>较新版本(不工作):http://jsfiddle.net/9nzcLar6/

HTML:

<select class="selectpicker Categoria" multiple="">
  <option selected>A1</option>
  <option selected>A2</option>
  <option>A3</option>
  <option>A4</option>
</select>
<input type="text" class="ChangeCategory" name="ChangeCategory">

JS:

$('select').selectpicker();

$(".Categoria").change(function() {
  f2();
});

var f2 = function(){
  $('.ChangeCategory').val($(".Categoria").val());
}
f2();

解决方法

一种解决方案是使用Array.from()和map方法获取所有选定的值.
var values=Array.from($(".Categoria").find(':selected')).map(function(item){
    return $(item).text();
});

工作方案

$('select').selectpicker();

$(".Categoria").change(function() {
  f2();
});

var f2 = function(){
   var values=Array.from($(".Categoria").find(':selected')).map(function(item){
      return $(item).text();
   });
   $('.ChangeCategory').val(values);
}
f2();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script>
<link href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.12.2/css/bootstrap-select.css" rel="stylesheet"/>
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.12.2/js/bootstrap-select.js"></script>
<script src="http://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>
<link href="http://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css" rel="stylesheet"/><select class="selectpicker Categoria" multiple="">
    <option selected>A1</option>
    <option selected>A2</option>
    <option>A3</option>
    <option>A4</option>
</select>
<input type="text" class="ChangeCategory" name="ChangeCategory">

您也可以使用箭头功能在一行代码中执行此操作.

$('.ChangeCategory').val(Array.from($( ".Categoria option:selected" )).map(a=>$(a).text()).join(','));

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...