一個簡單的方法是使用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>
感謝。我會使用javascript – Phoenix 2010-11-15 18:00:31