簡単な方法は、UI に jQuery を使用することです (そうすれば、面倒な JavaScript について心配したり、ブラウザーの互換性に対処したりする必要がなくなります)、データをサーバーに呼び出すことができます。サーバーの場合、ループする値に対して JSON を返すのが最も簡単な方法です。
jQuery を含めます。
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.4.3/jquery.min.js"></script>
次に、JavaScript のハンドルを追加します。
<script type="text/javascript">
function autoPopulate() {
var value1 = $('#ddl1').val();
var value2 = $('#ddl2').val();
var value3 = $('#ddl3').val();
var url = 'path/to/your/file.aspx?value1=' + value1 + '&value2=' + value2 + '&value3=' + value3;
$.getJSON(url, function(data) {
data == null ? return false : data = eval(data);
var ddl = $('#ddl4')[0];
for (i = 0; i < data.length; i++) {
var option = new Option(data[i][0], data[i][1]);
if ($.browser.msie) {
ddl.add(option);
} else {
ddl.add(option, null);
}
}
}
}
</script>
(はい、ネイティブループを使用したことは知っていますが、今日は少し怠惰です:))
ここで、サーバー側のコードでは、ページのコードが次の形式でデータを返すようにする必要があります。
[['value1','text1'],['value2','text2'],['value3','value3']]
次のようなもの:
<script type="vb" runat="server">
Private Sub Page_Init()
// get your data
// loop through it and add in values
// ex.
Dim result As String = "[" //start multi-dimensional array
For Each Item As String In data
result += String.Format("['{0}','{1}'],", _value, _text)
Next
result = result.SubString(0, result.Length - 1) // removes trailing comma
result += "]" // closes off m-array
Response.Write(result)
Response.Flush()
End Sub
</script>