Як встановити вибране значення jquery select2?


99

Це належать до кодів до select2 версії 4

У мене є простий код, select2який отримує дані від ajax

$("#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), щоб вибрати раніше вибране значення, але я не можу знайти спосіб.

ОНОВЛЕННЯ:

HTML-код:

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

Програмний доступ Select2 з цим не працює.


Ви повинні мати можливість просто встановити вибране значення в html або використовувати$("#programid").val()
Explosion Pills

@ExplosionPills Негативний, я спробував і це отримати пусте значення. Як я повинен використовувати programid.val ()? Я отримав значення з сервера, тоді мені потрібно встановити його у це приховане поле select2.
ClearBoth

@ClearBoth Не впевнений, чи розумію я те, що ти маєш на увазі. Ви намагаєтесь встановити "вибране" значення компонента Select2 як один із результатів, отриманих за допомогою AJAX?
Phan

@AnPhan Так, чи є спосіб це зробити?
ClearBoth

@ClearBoth Є. Перевірте мою відповідь нижче.
Phan

Відповіді:


61

Щоб динамічно встановити "вибране" значення компонента 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


1
Я намагався з ідентифікатором тільки select2 ('val', '1'), але не вийшло. Дякую
ClearBoth

6
Це працює, просто хотів зазначити, що в новому select2 "a_key" - це "текст" у стандартному об'єкті select2. так: {id: 100, text: 'Lorem Ipsum'}
NoobishPro

2
те саме тут на v4. Витягнув моє волосся на цьому. Я не думаю, що це можливо без переходу на рішення JavaScript. Шукаєте ще одне спадне меню jQuery / Bootstrap Select2 (2 дні, щоб обмірковувати кожен можливий метод - немає радості!)
MC9000

29
Select2 v4: $('#inputID').val(100).trigger('change') Дивіться select2.github.io/…
Павло

@NoobishPro & An Phan - Дякую за відповідь та коментар
Sinto

104

SELECT2 <V4


Крок No1: 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!"});

Якщо ви використовуєте select2 без AJAX, ви можете зробити наступне:

<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");

SELECT2 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');

3
тригер ('зміна'); є важливою частиною
mihkov

$ ("# mySelect2"). select2 ("val", "0") - це спричинить подію jquery змін значення. Як цього не сталося. Зазвичай, коли користувач надсилає форму, після закінчення я скидаю всі дані форми. Скидання не скине select2. Використання select2 ("val", "0") призведе до змін, що є божевільним, оскільки користувача не буде діяти.
джемпер rbk


Вітається за .trigger ('зміна')
JP Dolocanog

23

Html:

<select id="lang" >
   <option value="php">php</option>
   <option value="asp">asp</option>
   <option value="java">java</option>
</select>

JavaScript:

$("#lang").select2().select2('val','asp');

jsfiddle


2
як встановити текст, а не val
Різван Патель

Питання полягало в тому, як це зробити після завантаження за допомогою виклику AJAX. Ця відповідь не працює в цьому випадку.
MC9000

це спричинить зміни значення select2, що буде дивним, якщо вам потрібно обробити цю подію, і це спрацювало без того, щоб це зробив користувач
jumper rbk

17

Крім того, як я намагався, коли я використовую ajax у select2, програмні методи управління для встановлення нових значень у select2 для мене не працюють! Тепер я пишу цей код для вирішення проблеми:

$('#sel')
    .empty() //empty select
    .append($("<option/>") //add option tag in select
        .val("20") //set value for option to post it
        .text("nabi")) //set a text for show in select
    .val("20") //select option of select2
    .trigger("change"); //apply to select2

Ви можете перевірити повний зразок коду за посиланням: https://jsfiddle.net/NabiKAZ/2g1qq26v/32/
У цьому прикладі коду є ajax select2, і ви можете встановити нове значення за допомогою кнопки.


Я використовую різні displayKey та інші речі (це була погана ідея) - це допомагає моїм тестам на прийняття з Codeception ідеально
MonkeyMonkey

2
Втомливо, звичайно, але, як і всі з’ясовують, Select2 v4 просто не може зробити щось настільки смішно просте, як встановлення вибору за замовчуванням
MC9000

Я знайшов цю відповідь єдиним способом зробити select2 v4 - ajax select.

13
var $option = $("<option selected></option>").val('1').text("Pick me");

$('#select_id').append($option).trigger('change');

Спробуйте цей додаток, а потім виберіть. Не дублює цю опцію при виклику AJAX.


var $ option = $ ("<параметр вибраний> </option>") .val ('1'). текст ("Виберіть мене"); $ ('# select_id'). додавати ($ параметр) .trigger ('змінити);
Джигз

Дякую. підтверджено роботи над версією 4.0.0 (ajax call)
халіл

Ще один підтверджений успіх у версії 4 з ajax.
програміст

Якщо ви використовуєте поле для пошуку з ajax, це правильне рішення. Цей працював на мене червень 2019 року.
Ерік

12

Мені це подобалось-

$("#drpServices").select2().val("0").trigger("change");

2
Надайте трохи пояснень, щоб допомогти користувачам зрозуміти, як працює ваш код, і відповісти на питання ОП.
Іван

@Ivan, я робив так, як це $ ("# drpServices"). Val ("0"); який не вибере текстовий текст у спадному меню select2, для впливу як на значення, так і на текст нам потрібна функція зміни тригера select2. Це прекрасно працює для мене. Сподіваюся, користувачі зрозуміють.
Аші

9

У поточній версії увімкнено select2- v4.0.1 ви можете встановити значення таким чином:

var $example = $('.js-example-programmatic').select2();
$(".js-programmatic-set-val").on("click", function () { $example.val("CA").trigger("change"); });

// Option 2 if you can't trigger the change event.
var $exampleDestroy = $('.js-example-programmatic-destroy').select2();
$(".js-programmatic-set-val").on("click", function () { $exampleDestroy.val("CA").select2('destroy').select2(); });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.1/js/select2.min.js"></script>
<link href="//cdnjs.cloudflare.com/ajax/libs/select2/4.0.1/css/select2.min.css" rel="stylesheet" />

using "trigger(change)"
<select class="js-example-programmatic">
  <optgroup label="Alaskan/Hawaiian Time Zone">
    <option value="AK">Alaska</option>
    <option value="HI">Hawaii</option>
  </optgroup>
  <optgroup label="Pacific Time Zone">
    <option value="CA">California</option>
    <option value="NV">Nevada</option>
    <option value="OR">Oregon</option>
    <option value="WA">Washington</option>
  </optgroup>
  <optgroup label="Mountain Time Zone">
    <option value="AZ">Arizona</option>
    <option value="CO">Colorado</option>
    <option value="ID">Idaho</option>
    <option value="MT">Montana</option>
    <option value="NE">Nebraska</option>
    <option value="NM">New Mexico</option>
    <option value="ND">North Dakota</option>
    <option value="UT">Utah</option>
    <option value="WY">Wyoming</option>
  </optgroup>
  <optgroup label="Central Time Zone">
    <option value="AL">Alabama</option>
    <option value="AR">Arkansas</option>
    <option value="IL">Illinois</option>
    <option value="IA">Iowa</option>
    <option value="KS">Kansas</option>
    <option value="KY">Kentucky</option>
    <option value="LA">Louisiana</option>
    <option value="MN">Minnesota</option>
    <option value="MS">Mississippi</option>
    <option value="MO">Missouri</option>
    <option value="OK">Oklahoma</option>
    <option value="SD">South Dakota</option>
    <option value="TX">Texas</option>
    <option value="TN">Tennessee</option>
    <option value="WI">Wisconsin</option>
  </optgroup>
  <optgroup label="Eastern Time Zone">
    <option value="CT">Connecticut</option>
    <option value="DE">Delaware</option>
    <option value="FL">Florida</option>
    <option value="GA">Georgia</option>
    <option value="IN">Indiana</option>
    <option value="ME">Maine</option>
    <option value="MD">Maryland</option>
    <option value="MA">Massachusetts</option>
    <option value="MI">Michigan</option>
    <option value="NH">New Hampshire</option>
    <option value="NJ">New Jersey</option>
    <option value="NY">New York</option>
    <option value="NC">North Carolina</option>
    <option value="OH">Ohio</option>
    <option value="PA">Pennsylvania</option>
    <option value="RI">Rhode Island</option>
    <option value="SC">South Carolina</option>
    <option value="VT">Vermont</option>
    <option value="VA">Virginia</option>
    <option value="WV">West Virginia</option>
  </optgroup>
</select>

using destroy: 
<select class="js-example-programmatic">
  <optgroup label="Alaskan/Hawaiian Time Zone">
    <option value="AK">Alaska</option>
    <option value="HI">Hawaii</option>
  </optgroup>
  <optgroup label="Pacific Time Zone">
    <option value="CA">California</option>
    <option value="NV">Nevada</option>
    <option value="OR">Oregon</option>
    <option value="WA">Washington</option>
  </optgroup>
  <optgroup label="Mountain Time Zone">
    <option value="AZ">Arizona</option>
    <option value="CO">Colorado</option>
    <option value="ID">Idaho</option>
    <option value="MT">Montana</option>
    <option value="NE">Nebraska</option>
    <option value="NM">New Mexico</option>
    <option value="ND">North Dakota</option>
    <option value="UT">Utah</option>
    <option value="WY">Wyoming</option>
  </optgroup>
  <optgroup label="Central Time Zone">
    <option value="AL">Alabama</option>
    <option value="AR">Arkansas</option>
    <option value="IL">Illinois</option>
    <option value="IA">Iowa</option>
    <option value="KS">Kansas</option>
    <option value="KY">Kentucky</option>
    <option value="LA">Louisiana</option>
    <option value="MN">Minnesota</option>
    <option value="MS">Mississippi</option>
    <option value="MO">Missouri</option>
    <option value="OK">Oklahoma</option>
    <option value="SD">South Dakota</option>
    <option value="TX">Texas</option>
    <option value="TN">Tennessee</option>
    <option value="WI">Wisconsin</option>
  </optgroup>
  <optgroup label="Eastern Time Zone">
    <option value="CT">Connecticut</option>
    <option value="DE">Delaware</option>
    <option value="FL">Florida</option>
    <option value="GA">Georgia</option>
    <option value="IN">Indiana</option>
    <option value="ME">Maine</option>
    <option value="MD">Maryland</option>
    <option value="MA">Massachusetts</option>
    <option value="MI">Michigan</option>
    <option value="NH">New Hampshire</option>
    <option value="NJ">New Jersey</option>
    <option value="NY">New York</option>
    <option value="NC">North Carolina</option>
    <option value="OH">Ohio</option>
    <option value="PA">Pennsylvania</option>
    <option value="RI">Rhode Island</option>
    <option value="SC">South Carolina</option>
    <option value="VT">Vermont</option>
    <option value="VA">Virginia</option>
    <option value="WV">West Virginia</option>
  </optgroup>
</select>

<button class="js-programmatic-set-val">set value</button>


Як я можу встановити значення, не викликаючи події зміни? Подія зміни викликає мої власні обробники подій, призначені для того, коли користувач змінює значення вручну.
enumag

Інший варіант - це destroyповторний виклик плагіна. Перегляньте оновлений код ..
Mosh Feu

Чи є спосіб отримати варіанти, які я спочатку передав select2, щоб мені не довелося дублювати їх? У будь-якому випадку це рішення здається більше схожим на хакерство.
enumag

Звичайно, це хач. Офіційний спосіб згідно з документами - ініціювати подію зміни. so that I wouldn't have to duplicate themЧому їх потрібно дублювати? Коли ви все ще там з усіма його . destroyselectoptions
Mosh Feu

Я мав на увазі варіанти, передані для select2:$example.select2({ ... this ... })
enumag

6

Для Ajax використовуйте $(".select2").val("").trigger("change"). Це має вирішити проблему.


6

Я думаю, вам потрібна initSelectionфункція

$("#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};
    }
  },
  initSelection: function (element, callback) {
    var id = $(element).val();
    if (id !== "") {
      $.ajax("ajax.php/get_where", {
        data: {programid: id},
        dataType: "json"
      }).done(function (data) {
        $.each(data, function (i, value) {
          callback({"text": value.text, "id": value.id});
        });
        ;
      });
    }
  },
  dropdownCssClass: "bigdrop",
  escapeMarkup: function (m) { return m; }
});

Це працює. Але застарілий із версії 4.0
VisualBean


5

У Select2 V.4

використання $('selector').select2().val(value_to_select).trigger('change');

Я думаю, це має спрацювати


3

Встановіть значення та негайно ініціюйте подію зміни.

$('#selectteam').val([183,182]).trigger('change');

Дякую вам того самого дня
Jaydeep purohit

3
    $("#select_location_id").val(value);
    $("#select_location_id").select2().trigger('change');

Я вирішив свою проблему за допомогою цього простого коду. Де #select_location_id - ідентифікатор вікна вибору, а значення - значення параметра, вказаного у полі select2.


2

Відповідь Фана мені спрацювала:

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

Але додавання змін викликає подію

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

1
Я отримую помилку "Uncaught TypeError: $ (...). Select2 (...). Зміна не є функцією (...)", роблячи це таким чином. Я не думаю, що це можливо з версією 4.x Select2 - тут нічого не працює з ajax.
MC9000

2

Ви можете використовувати цей код:

$("#programid").val(["number:2", "number:3"]).trigger("change");

де 2 в "число: 2" і 3 в "число: 3" - поле id в масиві об'єктів


1

Іноді select2()спочатку завантажується, і це робить елемент керування неправильним відображенням раніше вибраного значення. Якщо поставити затримку на кілька секунд, ця проблема може бути вирішена.

setTimeout(function(){                  
    $('#costcentreid').select2();               
},3000);


0

Я зробив щось подібне для попереднього встановлення елементів у випадаючому списку select2 ajax

      //preset element values
        $(id).val(topics);
       //topics is an array of format [{"id":"","text":""}, .....]
          setTimeout(function(){
           ajaxTopicDropdown(id,
                2,location.origin+"/api for gettings topics/",
                "Pick a topic", true, 5);                      
            },1);
        // ajaxtopicDropdown is dry fucntion to get topics for diffrent element and url

0

Ви повинні використовувати:

var autocompleteIds= $("#EventId");
autocompleteIds.empty().append('<option value="Id">Text</option>').val("Id").trigger('change');

// For set multi selected values
var data =  [];//Array Ids
var option =  [];//Array options of Ids above
autocompleteIds.empty().append(option).val(data).trigger('change');

// Callback handler that will be called on success
request.done(function (response, textStatus, jqXHR) {
    // append the new option
    $("#EventId").append('<option value="' + response.id + '">' + response.text + '</option>');

    // get a list of selected values if any - or create an empty array
    var selectedValues = $("#EventId").val();
    if (selectedValues == null) {
        selectedValues = new Array();
    }
    selectedValues.push(response.id);   // add the newly created option to the list of selected items
    $("#EventId").val(selectedValues).trigger('change');   // have select2 do it's thing
});

0

Якщо ви використовуєте поле Введення, ви повинні встановити властивість "кілька" зі своїм значенням "істинним". Наприклад,

<script>
    $(document).ready(function () {

        var arr = [{ id: 100, text: 'Lorem Ipsum 1' },
            { id: 200, text: 'Lorem Ipsum 2'}];

        $('#inputID').select2({
            data: arr,
            width: 200,
            multiple: true
        });
    });
</script>

0

В select2 < version4є можливість initSelection()для віддаленого завантаження даних, з допомогою яких можна встановити початкове значення для введення , як і в режимі редагування.

$("#e6").select2({
    placeholder: "Search for a repository",
    minimumInputLength: 1,
    ajax: { 
        // instead of writing the function to execute the request we use Select2's convenient helper
        url: "https://api.github.com/search/repositories",
        dataType: 'json',
        quietMillis: 250,
        data: function (term, page) {
            return {
                q: term, // search term
            };
        },
        results: function (data, page) {
            // parse the results into the format expected by Select2.
            // since we are using custom formatting functions we do not need to alter the remote JSON data
            return { results: data.items };
        },
        cache: true
    },
    initSelection: function(element, callback) {
        // the input tag has a value attribute preloaded that points to a preselected repository's id
        // this function resolves that id attribute to an object that select2 can render
        // using its formatResult renderer - that way the repository name is shown preselected
        var id = $(element).val();
        if (id !== "") {
            $.ajax("https://api.github.com/repositories/" + id, {
                dataType: "json"
            }).done(function(data) { callback(data); });
        }
    },
    formatResult: repoFormatResult, // omitted for brevity, see the source of this page
    formatSelection: repoFormatSelection,  // omitted for brevity, see the source of this page
    dropdownCssClass: "bigdrop", // apply css that makes the dropdown taller
    escapeMarkup: function (m) { return m; } // we do not want to escape markup since we are displaying html in results
});

Документація джерела: Select2 - 3.5.3


0

Просто додати до когось іншого, хто, можливо, зі мною придумав те саме.

Я намагався встановити вибраний варіант моїх динамічно завантажених параметрів (від AJAX) і намагався встановити один із варіантів, вибраних у залежності від певної логіки.

Моя проблема виникла тому, що я не намагався встановити вибраний варіант на основі ідентифікатора, який повинен відповідати значенню, а не значенню, що відповідає імені!


0

Для кількох значень приблизно так:

$("#HouseIds").select2("val", @Newtonsoft.Json.JsonConvert.SerializeObject(Model.HouseIds));

що перекладе щось подібне

$("#HouseIds").select2("val", [35293,49525]);

0

Це може допомогти комусь завантажувати дані select2 з AJAX під час завантаження даних для редагування ( застосовується для одного або декількох варіантів ):

Під час завантаження форми / моделі:

  $.ajax({
        type: "POST",
        ...        
        success: function (data) {
          selectCountries(fixedEncodeURI(data.countries));
         }

Зателефонуйте, щоб вибрати дані для Select2:

var countrySelect = $('.select_country');
function selectCountries(countries)
    {
        if (countries) {
            $.ajax({
                type: 'GET',
                url: "/regions/getCountries/",
                data: $.param({ 'idsSelected': countries }, true),

            }).then(function (data) {
                // create the option and append to Select2                     
                $.each(data, function (index, value) {
                    var option = new Option(value.text, value.id, true, true);
                    countrySelect.append(option).trigger('change');
                    console.log(option);
                });
                // manually trigger the `select2:select` event
                countrySelect.trigger({
                    type: 'select2:select',
                    params: {
                        data: data
                    }
                });
            });
        }
    }

і якщо у вас можуть виникнути проблеми з кодуванням, ви можете змінити як свою вимогу:

function fixedEncodeURI(str) {
        return encodeURI(str).replace(/%5B/g, '[').replace(/%5D/g, ']').replace(/%22/g,"");

    }

0

якщо ви отримуєте свої значення від ajax, перед викликом

$("#select_location_id").val(value);
$("#select_location_id").select2().trigger('change');

підтвердити, що виклик ajax завершено, використовуючи функцію jquery when

$.when(ajax1(), ajax2(), ajax3(), ajax4()).done(function(a1, a2, a3, a4){
      // the code here will be executed when all four ajax requests resolve.
      // a1, a2, a3 and a4 are lists of length 3 containing the response text,
      // status, and jqXHR object for each of the four ajax calls respectively.
    }); 
як описано тут [ Зачекайте, поки всі запити jQuery Ajax будуть виконані?


0

Побудувати поверх відповіді @ tomloprod. Швидше за все , ви використовуєте редагування x , і маєте поле select2 (v4) і маєте кілька елементів, які потрібно попередньо вибрати. Ви можете використовувати наступний фрагмент коду:

$("#select2field").on("shown", function(e, editable){
    $(["test1", "test2", "test3", "test4"]).each(function(k, v){
        // Create a DOM Option and pre-select by default~
        var newOption = new Option(v.text, v.id, true, true);
        // Append it to the select
        $(editable.input.$input).append(newOption).trigger('change');
     });
});

і ось воно в дії:

var data = [
{
    id: 0,
    text: 'enhancement'
},
{
    id: 1,
    text: 'bug'
},
{
    id: 2,
    text: 'duplicate'
},
{
    id: 3,
    text: 'invalid'
},
{
    id: 4,
    text: 'wontfix'
}
];

$("#select2field").editable({
        type: "select2",
        url: './',
        name: 'select2field',
        savenochange: true,
        send: 'always',
        mode: 'inline',
        source: data,
        value: "bug, wontfix",
        tpl: '<select style="width: 201px;">',
        select2: {
            width: '201px',
            tags: true,
            tokenSeparators: [',', ' '],
            multiple: true,
            data:data
        },
        success: function(response, newValue) {
            console.log("success")
        },
        error: function(response, newValue) {
            if (response.status === 500) {
                return 'Service unavailable. Please try later.';
            } else {
                return response.responseJSON;
            }
        }
    });

var preselect= [
    {
        id: 1,
        text: 'bug'
    },
    {
    id: 4,
    text: 'wontfix'
}
];

 $("#select2field").on("shown", function(e, editable){
    $(preselect).each(function(k, v){
        // Create a DOM Option and pre-select by default~
        var newOption = new Option(v.text, v.id, true, true);
        // Append it to the select
        $(editable.input.$input).append(newOption).trigger('change');
     });
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.1/js/select2.min.js"></script>
<link href="//cdnjs.cloudflare.com/ajax/libs/select2/4.0.1/css/select2.min.css" rel="stylesheet" />

<link href="//cdnjs.cloudflare.com/ajax/libs/x-editable/1.5.0/bootstrap3-editable/css/bootstrap-editable.css" rel="stylesheet"/>
<script src="//cdnjs.cloudflare.com/ajax/libs/x-editable/1.5.0/bootstrap3-editable/js/bootstrap-editable.min.js"></script>

<a id="select2field">bug, wontfix</a>

Я думаю, що це спрацювало б навіть у тому випадку, якщо ви не використовуєте x-editable. Я сподіваюся, що htis може комусь допомогти.


0

Ви можете використовувати цей код:

    $('#country').select2("val", "Your_value").trigger('change');

Поставте бажане значення замість Your_value

Сподіваюся, це буде працювати :)


-2

Приємно і просто:

document.getElementById("select2-id_city-container").innerHTML = "Your Text Here";

І ти міняєшся id_city ідентифікатор вашого вибору.

Редагувати: Після коментаря Глена я розумію, що повинен пояснити, чому і як це працювало на мене:

Я зробив select2роботу дуже приємною для своєї форми. Єдине, що я не міг зробити роботу - це показати поточне вибране значення під час редагування. Він здійснював пошук стороннього API, зберігаючи нові та редагуючи старі записи. Через деякий час я зрозумів, що мені не потрібно правильно встановлювати значення, лише мітка всередині поля, тому що якщо користувач не змінить поле, нічого не станеться. Після пошуку та пошуку багатьох людей, які мають проблеми з цим, я вирішив зробити це на чистому Javascript. Це спрацювало, і я розмістив повідомлення, щоб допомогти комусь. Також пропоную встановити для нього таймер.


Ця відповідь - жахливий хак, який навіть не встановив би значення правильно.
Глен

Мені про це шкода. Я відредагую свою відповідь, щоб пояснити, чому я її розмістив.
bonafernando
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.