В моей форме есть поле со списком, которое запрашивает страну пользователя, но я хочу только заполнить поле со списком с помощью вызова AJAX, если в поле еще не отображается страна пользователя. Первоначально список содержит только одну страну — страну, полученную в результате поиска ip-to-country на сервере.
Похоже, что действие по умолчанию в списке происходит до моего действия по событию. Я хотел бы, чтобы мое действие выполнялось первым, чтобы, когда пользователь щелкает поле списка, поле было предварительно заполнено странами, удаленными с сервера, прежде чем окно откроется.
Спасибо за любые предложения.
$().ready(function() {
$('select#selCountry').one('click', function() {
var selCountry = $('select#selCountry');
var selected = $(selCountry).val();
selCountry.html('<option value="">Loading...</option>');
$.getJSON('/AjaxHelpers/CountryList', function(data) {
if (data.length) {
var options = '';
for (var i = 0; i < data.length; i++) {
var key = data[i].Key;
var val = data[i].Value;
options += '<option value="' + key + '"';
if (key == selected) {
options += ' selected="selected"';
}
options += '>' + val + '</option>';
}
selCountry.html(options);
}
else {
selCountry.html('<option value="">Failed.</option>');
}
});
});
});
HTML:
<div>
<select id="selCountry" name="CountryCode"><option value="GB">United Kingdom</option>