Вы не можете использовать $.each
таким образом. Посмотрите на API do c: jQuery .each () Do c Давайте предположим, что ваш вызов getJSON
действительно возвращает правильные данные. И вы получите массив, подобный этому
[
{text: 'Text 1', value: 1 },
{text: 'Text 2', value: 2 },
{text: 'Text 3', value: 3 }
];
Я бы настоятельно рекомендовал написать некоторую функцию для добавления вашего выбора и добавления опций, например так:
function addSelect( $element, addonText, selectName ) {
let $wrapper = $('<div class="col-md-2"></div>');
let $group = $('<div class="input-group col-md-3"></div>');
let $addon = $('<span class="input-group-addon"></span>').text(addonText);
let $select = $('<select name="'+ selectName +'" id="'+selectName+'" class="form-control"/>');
$group.append($addon).append($select);
$wrapper.append($group);
$element.append($wrapper);
}
и
function addOptions($select, text, value) {
$select.append($('<option></option>').text(text).val(value))
}
таким образом вы можете использовать эти функции в вашем getJSON
методе, например:
$.getJSON(ur, function (response) {
if (Object.keys(response).length) {
$.each(response, function(key, value) {
addSelect($('#participants), 'username', 'userids');
let $select = $('#userids');
addOptions($select, value.text, value.value);
});
}
});
Рабочий пример:
let r = [
{text: 'Text 1', value: 1 },
{text: 'Text 2', value: 2 },
{text: 'Text 3', value: 3 }
];
function addSelect( $element, addonText, selectName, options ) {
let $wrapper = $('<div class="col-md-2"></div>');
let $group = $('<div class="input-group col-md-3"></div>');
let $addon = $('<span class="input-group-addon"></span>').text(addonText);
let $select = $('<select name="'+ selectName +'" class="'+selectName+'" class="form-control"/>');
$group.append($addon).append($select);
$wrapper.append($group);
$element.append($wrapper);
$.each(options, function(key, value) {
addOptions($select, value.text, value.value);
});
}
function addOptions($select, text, value) {
$select.append($('<option></option>').text(text).val(value))
}
let clicked = 1;
$('#more').on('click', function() {
let currentId = clicked;
clicked++;
addSelect( $('#participants'), 'username ' + currentId, currentId, r );
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div id="participants">
</div>
<button id="more">
more
</button>