如何设置jQuery Select2的选定值?选择 2 < V4选择2 V4

2022-08-30 04:06:26

这属于 Select2 版本 4 之前的代码

我有一个简单的代码,从AJAX获取数据。select2

$("#programid").select2({
  placeholder: "Select a Program",
  allowClear: true,
  minimumInputLength: 3,
  ajax: {
    url: "ajax.php",
    dataType: 'json',
    quietMillis: 200,
    data: function (term, page) {
      return {
        term: term, //search term
        flag: 'selectprogram',
        page: page // page number
      };
    },
    results: function (data) {
      return {results: data};
    }
  },
  dropdownCssClass: "bigdrop",
  escapeMarkup: function (m) { return m; }
});

此代码正在工作,但是,我需要在其上设置一个值,就像在编辑模式下一样。当用户第一次选择一个值时,它将被保存,当他需要编辑该值时,它必须出现在相同的选择菜单()中以选择先前选择的值,但我找不到方法。select2

更新:

代码:

<input type="hidden" name="programid" id="programid" class="width-500 validate[required]">

Select2 编程访问不适用于此。


答案 1

选择 2 < V4


步骤#1:HTML

<input name="mySelect2" type="hidden" id="mySelect2">

步骤 #2:创建 Select2 的实例

$("#mySelect2").select2({
      placeholder: "My Select 2",
      multiple: false,
      minimumInputLength: 1,
      ajax: {
          url: "/elements/all",
          dataType: 'json',
          quietMillis: 250,
          data: function(term, page) {
              return {
                  q: term,
              };
          },
          results: function(data, page) {
              return {results: data};
          },
          cache: true
      },
      formatResult: function(element){
          return element.text + ' (' + element.id + ')';
      },
      formatSelection: function(element){
          return element.text + ' (' + element.id + ')';
      },
      escapeMarkup: function(m) {
          return m;
      }
});

步骤#3:设置所需的值

$("#mySelect2").select2('data', { id:"elementID", text: "Hello!"});

如果您使用不带AJAX的select2,则可以执行以下操作:

<select name="mySelect2" id="mySelect2">
  <option value="0">One</option>
  <option value="1">Two</option>
  <option value="2">Three</option>
</select>
/* "One" will be the selected option */
$('[name=mySelect2]').val("0");

您也可以这样做:

$("#mySelect2").select2("val", "0");

选择2 V4


对于 select2 v4,您可以直接附加一个选项,如下所示:

<select id="myMultipleSelect2" multiple="" name="myMultipleSelect2[]">
    <option value="TheID" selected="selected">The text</option>                                                                   
</select>

或者使用JQuery:

var $newOption = $("<option selected='selected'></option>").val("TheID").text("The text")
 
$("#myMultipleSelect2").append($newOption).trigger('change');

其他示例

$("#myMultipleSelect2").val(5).trigger('change');

答案 2

动态设置 Select2 组件的“选定”值:

$('#inputID').select2('data', {id: 100, a_key: 'Lorem Ipsum'});

其中,第二个参数是具有预期值的对象。

更新:

这确实有效,只是想注意,在新的select2中,“a_key”是标准select2对象中的“文本”。所以:{id: 100, text: 'Lorem Ipsum'}

例:

$('#all_contacts').select2('data', {id: '123', text: 'res_data.primary_email'});

感谢@NoobishPro