フォームにはユーザーの国を尋ねるリストボックスがありますが、リストボックスにはAJAXコールを使用して、すでにユーザーの国を表示していません。当初、リストボックスには1つの国のみが含まれていました。国はサーバー上でIPから国へのルックアップから返されました。jqueryとボックスのクリックイベントを使用して国名のリストボックスを自動入力する
リストボックスのデフォルトアクションは、イベントアクションの前に発生しているようです。ユーザーがリストボックスをクリックすると、ボックスが開かれる前にサーバーから引き出された国がボックスにあらかじめ入力されるように、アクションが最初に発生するようにしたいと思います。
ありがとうございます。
$().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>
"デフォルトアクション"とは何ですか?このコードではどういうことが起こるのですか?起こりたくないのですか? – mkoryak