私は非常にイライラする問題を抱えています。結果をフィルタリングして選択ボックスに入力するこのコードがあります
var syn = <?=json_encode($syn)?>;
function filterByCity() {
var e = document.getElementById("city_filter");
var city = e.options[e.selectedIndex].value;
var selectOptions = document.getElementById('syn_list');
selectOptions.options.length = 0;
for (i = 0; i < syn.length; i++) {
if (city == syn[i]['city'] || city == 'all') {
selectOptions.options[selectOptions.options.length] = new Option(syn[i]['name'], syn[i]['id'] + '" onclick="updateTxtContent(\'' + syn[i]['id'] + '\')');
}
}
}
ご覧のとおり、ページ自体のソースコードで見栄えのするすべての選択「オプション」に onclick リスナーを追加していますが、それを編集にコピーすると、「updateTxtContent()」関数が呼び出されません。
<select size="10" name="syn_list" id="syn_list" class="span12" dir="rtl" style="text-align:right;">
<option value="13" onclick="updateTxtContent('13')">option a</option>
<option value="14" onclick="updateTxtContent('14')">option b</option>
明らかに、私が気付いていないこれを行うためのより良い方法があるはずです。