用ajax实现了联动,可是在后台代码中不能用dropdownlist2.SelectedItem.Text取得第二个的值,总是得到空值
来源:互联网 发布:众途汽车软件 编辑:程序博客网 时间:2024/05/16 07:15
用ajax实现了联动,可是在后台代码中不能用dropdownlist2.SelectedItem.Text取得第二个的值,总是得到空值
html
<%@ Page EnableEventValidation="false" Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>AjaxPro实现无刷新三级联动</title>
</head>
<script language="javascript" type="text/javascript">
<!--
// ACLOUD 常用JS函数
function getBid(s){
return document.getElementById(s);
}
function getBmc(s){
return document.getElementByName(s);
}
//显示分类列表
function showNext(sid,obj)
{
if(sid==null || sid=="" || sid.length<1)return;
var slt =getBid(obj);
var v = _Default.getNextClass(sid).value; // 类的名称
//alert(v);
//return;
if (v != null){
if(v != null && typeof(v) == "object" && v.Tables != null)
{
slt.length = 0;
slt.options.add(new Option("请选择",0));
//加了个“请选择”主要为了触发onchange事件
if(obj=="ddl2"){
getBid("ddl3").options.length=0;
getBid("ddl3").options.add(new Option("请选择",0));
}
for(var i=0; i<v.Tables[0].Rows.length; i++)
{
var txt = v.Tables[0].Rows[i].txt; //这个地方需要注意区分大小写
var vol = v.Tables[0].Rows[i].vol; //跟dataset表的列名称要一致
slt.options.add(new Option(txt,vol));
}
}
}
return;
}
-->
</script>
<body>
<form id="form1" runat="server">
<div>
<table width="500" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td width="99"> </td>
<td width="401">
城市<asp:DropDownList ID="ddl1" runat="server">
</asp:DropDownList>
区域<asp:DropDownList ID="ddl2" runat="server">
</asp:DropDownList>
花园<asp:DropDownList ID="ddl3" runat="server">
</asp:DropDownList></td>
</tr>
<tr>
<td> </td>
<td> </td>
</tr>
<tr>
<td> </td>
<td> </td>
</tr>
</table>
</div>
</form>
</body>
</html>
cs
using System;
using System.Data;
using System.Configuration;
using System.Data.OleDb;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default)); //必要的
if(!IsPostBack)BindDc();
}
/// <summary>
/// 数据库连接
/// </summary>
/// <returns></returns>
public OleDbConnection myConn()
{
string ConnStr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + System.Web.HttpContext.Current.Server.MapPath(ConfigurationManager.AppSettings["dbpath"]);
OleDbConnection conn = new OleDbConnection(ConnStr);
try
{
conn.Open();
return conn;
}
catch
{
throw;
}
}
/// <summary>
/// 获取下级分类
/// </summary>
[AjaxPro.AjaxMethod]
public DataSet getNextClass(string cid)
{
//因为不希望页面可以知道字段名称 所以 as txt,id as vol 如果是sql ser 可以用 =
//页面获取的 列名称 必须跟这个一同样 而且区分大小写 一般都是这个地方容易疏忽了
//所以二级分类没变化
string sql = @"select cname as txt,id as vol from webclass where parentid=" + cid;
try
{
return getDs(sql);
}
catch
{
//throw;
return null;
}
}
/// <summary>
/// 返回一个DataSet
/// </summary>
/// <param name="SQL"></param>
/// <returns></returns>
public DataSet getDs(string SQL)
{
OleDbConnection conn = myConn();
DataSet Ds = new DataSet();
OleDbDataAdapter Da = new OleDbDataAdapter(SQL, conn);
try
{
Da.Fill(Ds);
return Ds;
}
catch
{
return null;
//throw;
}
}
/// <summary>
/// //数据绑定
/// </summary>
private void BindDc()
{
//第一个
string sql = @"select * from webclass where Parentid=0";
ddl1.DataSource = getDs(sql);
ddl1.DataTextField = "cname";
ddl1.DataValueField = "id";
ddl1.DataBind();
if (ddl1.DataSource != null) ddl1.Attributes.Add("onchange", "showNext(this.options[selectedIndex].value,'ddl2');");
//可以先判断 DropDownList.SelectedItem.Value
//第二个
sql = @"select * from webclass where parentid=" + ddl1.SelectedItem.Value;
ddl2.DataSource = getDs(sql);
ddl2.DataTextField = "cname";
ddl2.DataValueField = "id";
ddl2.DataBind();
//第三个
if (ddl2.DataSource != null) ddl2.Attributes.Add("onchange", "showNext(this.options[selectedIndex].value,'ddl3');");
sql = @"select * from webclass where parentid=" + ddl2.SelectedItem.Value;
ddl3.DataSource = getDs(sql);
ddl3.DataTextField = "cname";
ddl3.DataValueField = "id";
ddl3.DataBind();
}
}
用ajax实现了联动,可是在后台代码中不能用dropdownlist2.SelectedItem.Text取得第二个的值,总是得到空值
用Request.Params[XXX.UniqueID] 即可获得该控件的值
- 用ajax实现了联动,可是在后台代码中不能用dropdownlist2.SelectedItem.Text取得第二个的值,总是得到空值
- 前台repeater中循环绑定了input的text控件,怎么在后台循环遍历text的值。
- 用JS选取DropDownList2 的值
- 在Javascript 中给label控件的 innerHTML 赋值,在后台获取不到 text值
- C# DropDownList 控件SelectedItem总是取第一个ListItem的值原因
- 产品编辑页面 使联动的DropDownList1 DropDownList2显示原来显示的值
- JS向隐藏域中传值然后在后台得到隐藏域的值
- oracle 查询 两个字段,第一个和第二个字段不为空时,就用第二个字段的值, 否则用第一个字段的
- 在后台[复制代码]功能键的js实现
- 在后台代码中动态的加载css
- asp.net中在后台更换控件图片的代码
- 在后台代码中引入XAML的方法
- wpf在后台代码中编写绑定
- ID和Name的问题------写个<input type="hidden">在后台取不到值
- 【学习笔记】〖ASP.NET〗在后台代码中取到控件旧值的解决办法
- ASP.NET中在后台用C#,往前台插入HTML代码
- ASP.NET中在后台用C#,往前台插入HTML代码
- 为什么刷机后开发环境的adb不能用了,总是显示设备“offline”?
- AJAX简单实现新闻拖放系统
- Struts2自带自动完成功能的问题
- 搭建适合开发人员的Oracle10g环境
- (原创)利用克拉默法则求解多元一次方程组
- Page.IsValid 属性
- 用ajax实现了联动,可是在后台代码中不能用dropdownlist2.SelectedItem.Text取得第二个的值,总是得到空值
- JAVA例题集合
- 回发或回调参数无效。在配置中使用或在页面中使用 <%@ Page EnableEventValidation="true" %
- 一个C# 事件的简单例子
- 编码之间的问题,其解决方法是在Web.config中添加
- 客户端调用服务器控件的客户端ID
- 一个好程序员的三个条件
- 不要想当然,原来ASP与ASP.NET不能共享会话(Session)
- 设置apache默认打开网页类型