jQueryJSON 無刷新三級聯動

作者: zengxiangzhan  來源: 博客園  發布時間: 2010-02-22 11:07  閱讀: 2300 次  推薦: 0   原文鏈接   [收藏]  

曾祥展

曾祥展

 
<asp:DropDownList ID="ddl1" runat="server" Width="100px" ></asp:DropDownList>
<asp:DropDownList ID="ddl2" runat="server" Width="100px" ></asp:DropDownList>
<asp:DropDownList ID="ddl3" runat="server" Width="100px" ></asp:DropDownList>

js:

 
<script src="js/jquery-1.4.2.min.js" type="text/javascript" ></script> 
<script type="text/javascript">

$(document).ready(function () {
GetA();
$(
"#ddl1").change(function () { GetB(); });
$(
"#ddl2").change(function () { GetC(); });
});


function GetA()
{
$(
"#ddl1").html("");
$(
"#ddl1").append("<option value='-1' selected='selected'>請選擇...</option>");
//$("select[name$=ddl1] > option:selected").remove();
var strId = 0;
$.getJSON(
"LoadClass.ashx?ddlId=" + strId, function (data) {
for (var i = 0; i < data.length; i++) {
$(
"select[name$=ddl1]").append($("<option></option>").val(data[i].ID).html(data
[i].Cname));
};
GetB();
});

}

function GetB()
{
$(
"#ddl2").html(""); $("#ddl3").html("");
var strId = $("#ddl1").attr("value");
if (strId != 0) {
$.getJSON(
"LoadClass.ashx?ddlId=" + strId, function (data) {
for (var i = 0; i < data.length; i++) {
$(
"select[name$=ddl2]").append($("<option></option>").val(data[i].ID).
html(data[i].Cname));
};
GetC();
});
}
}

function GetC()
{
$(
"#ddl3").html("");
var strId = $("#ddl2").attr("value");
if (strId != 0) {
$.getJSON(
"LoadClass.ashx?ddlId=" + strId, function (data) {
for (var i = 0; i < data.length; i++) {
$(
"select[name$=ddl3]").append($("<option></option>").val(data[i].ID).
html(data[i].Cname));
};
});
}
}

</script>

LoadClass.ashx:

 
<%@ WebHandler Language="C#" Class="LoadClass" %>

using System;
using System.Web;

using System.Text;
using System.Data;

public class LoadClass : IHttpHandler {

public void ProcessRequest (HttpContext context) {
// 數組 [{"ID":"275","Cname":"A1"},{"ID":"319","Cname":"A2"},{"ID":"322","Cname":"
A3"}]

int strId = Convert.ToInt32(context.Request["ddlId"]);
string strSQL = "select * from Class where parent_Ptr=" + strId + " order by class
Order asc
";
db d
= new db();
DataTable dt
= d.getDT(strSQL);
StringBuilder strClass
= new StringBuilder();
if (dt != null)
{
strClass.Append(
"[");
for (int i = 0; i < dt.Rows.Count; i++)
{
strClass.Append(
"{");
strClass.Append(
"\"ID\":\"" + dt.Rows[i]["id"].ToString() + "\",");
strClass.Append(
"\"Cname\":\"" + dt.Rows[i]["classCname"].ToString() + "\"");

if (i != dt.Rows.Count - 1)
{
strClass.Append(
"},");
}
}
}
strClass.Append(
"}");
strClass.Append(
"]");
context.Response.ContentType
= "application/json";
context.Response.ContentEncoding
= Encoding.UTF8;
context.Response.Write(strClass.ToString());
context.Response.End();
}

public bool IsReusable {
get {
return false;
}
}
}

注意:

代碼
 
//后臺只能獲取value值,不能直接獲取text,需要通過js、控件中轉
//結果:275 276 277
Label1.Text = Request.Form[ddl1.UniqueID] + " "
+ Request.Form["ddl2"] + " "
+ Request.Form[ddl3.ClientID.Replace("_", "$")] ;

遇到的問題:下拉框text的值通過HiddenField控件中轉

 
<asp:HiddenField ID="HiddenField1" runat="server" />
<asp:HiddenField ID="HiddenField2" runat="server" />
<asp:HiddenField ID="HiddenField3" runat="server" />

把選中下拉框的值賦予隱藏控件中:

 
<script type="text/javascript">
var Key1 = $("#ddl1>option:selected").val();
$(
'#HiddenField1').val(Key1);
var Key2 = $("#ddl2>option:selected").val();
$(
'#HiddenField2').val(Key2);
var Key3 = $("#ddl3>option:selected").val();
$(
'#HiddenField3').val(Key3);
</script>

選擇下拉框后 動態賦值到HiddenField 控件中的值 無法與下拉框選中的值相對應!可能與初始化有關,賦值這段代碼應該放到什么地方呢?或者有什么好的方法,歡迎討論?

0
0
 
標簽:jQuery JSON
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()