一个简单的方法是使用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