[100分]客户端checkboxlist选定项改变事件

yaojian524 2007-04-19 04:44:02
我想用javascript根据checkboxlist的选定项中是否有指定项(如“天气”),来控制一个dropdownlist控件是否显示,不能在后台写,因为不想刷新页面。checkboxlist的datasource是从数据库绑定的,因为数量是动态的,所以不能用checkbox
有没有什么好的实现办法?还请大家多帮忙!
...全文
1006 27 打赏 收藏 转发到动态 举报
写回复
用AI写文章
27 条回复
切换为时间正序
请发表友善的回复…
发表回复
yaojian524 2007-04-23
  • 打赏
  • 举报
回复
明白了,多谢了!
孟子E章 2007-04-23
  • 打赏
  • 举报
回复
另外因为页面继承了master页,所以没有body,没法用onload事件??
总的页面是有的

window.onload=function(){alert("ok")}
服务器端的Page_Load更没有问题
babay2008 2007-04-23
  • 打赏
  • 举报
回复
up
shushangdeyezi 2007-04-21
  • 打赏
  • 举报
回复
uping............................................................................................小女帮你顶一次
StarCraftPJF 2007-04-21
  • 打赏
  • 举报
回复
学习………………………………
yaojian524 2007-04-21
  • 打赏
  • 举报
回复
OnClick该成OnCheckedChanged事件试试
============================
试过,不行
yaojian524 2007-04-21
  • 打赏
  • 举报
回复
up
阿非 2007-04-20
  • 打赏
  • 举报
回复
jf
yaojian52401 2007-04-20
  • 打赏
  • 举报
回复
大家也帮忙看看
yaojian52401 2007-04-20
  • 打赏
  • 举报
回复
我知道了,放后台就行了
不过我是想该项被选中时触发事件,不是点击时触发,该怎么做呢?
qinqincl 2007-04-20
  • 打赏
  • 举报
回复
OnClick该成OnCheckedChanged事件试试
yaojian524 2007-04-19
  • 打赏
  • 举报
回复
另外因为页面继承了master页,所以没有body,没法用onload事件
yaojian524 2007-04-19
  • 打赏
  • 举报
回复
老大再来看一眼啊
yaojian524 2007-04-19
  • 打赏
  • 举报
回复
前台如果用了protected void Page_Load( object sender, EventArgs e ),后台的就被屏蔽了,能把前台的换个名字吗?也让它在初始化页面时执行?
孟子E章 2007-04-19
  • 打赏
  • 举报
回复
或者
<%@ Page Language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">

protected void Page_Load( object sender, EventArgs e )
{
if (!Page.IsPostBack)
{
string[] a = { "天气", "B", "C"};
CheckBoxList1.DataSource = a;
CheckBoxList1.DataBind();
for (int i = 0 ; i < CheckBoxList1.Items.Count ; i++)
{
if (CheckBoxList1.Items[i].Text == "天气")
{
CheckBoxList1.Items[i].Attributes.Add("onclick", "if(this.checked) {document.getElementById('" + DropDownList1.ClientID + "').style.display='none'}else{document.getElementById('" + DropDownList1.ClientID + "').style.display=''}");
}
}
}
}
</script>

<html xmlns="http://www.w3.org/1999/xhtml" >
<head id="Head1" runat="server">
<title>无标题页</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:CheckBoxList ID="CheckBoxList1" runat="server" AutoPostBack="false">
</asp:CheckBoxList></div>
<asp:DropDownList ID="DropDownList1" runat="server">
</asp:DropDownList>
</form>
</body>
</html>


也可以这样

<%@ Page Language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">

protected void Page_Load( object sender, EventArgs e )
{
if (!Page.IsPostBack)
{
string[] a = { "天气", "B", "C" };
CheckBoxList1.DataSource = a;
CheckBoxList1.DataBind();
for (int i = 0 ; i < CheckBoxList1.Items.Count ; i++)
{
CheckBoxList1.Items[i].Attributes.Add("onclick", "ClickMe(this)");
}
}
}
</script>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>

<script type="text/javascript">
function ClickMe(o)
{
var boxid = "<%=CheckBoxList1.ClientID %>"
var boxs = document.getElementsByTagName("INPUT")
for(i = 0;i<boxs.length;i++)
{
if(boxs[i].id.substr(0,boxid.length) == boxid)
{
var chname = boxs[i].nextSibling.innerHTML

if(chname == "天气" && boxs[i].checked)
{
document.getElementById('<%=DropDownList1.ClientID%>').style.display='none';
break;
}
else
{
document.getElementById('<%=DropDownList1.ClientID%>').style.display='';
}
}
}
}

</script>

</head>
<body>
<form id="form1" runat="server">
<div>
<asp:CheckBoxList ID="CheckBoxList1" runat="server" AutoPostBack="false">
</asp:CheckBoxList></div>
<asp:DropDownList ID="DropDownList1" runat="server">
</asp:DropDownList>
</form>
</body>
</html>

随你的需要而定
jiangtoby 2007-04-19
  • 打赏
  • 举报
回复
mark
孟子E章 2007-04-19
  • 打赏
  • 举报
回复
没事,有好的做法尽管说
leixueqiyi 2007-04-19
  • 打赏
  • 举报
回复
每次孟子在,都没发言机会
shaohaiou 2007-04-19
  • 打赏
  • 举报
回复
迟来一步
孟子E章 2007-04-19
  • 打赏
  • 举报
回复
<%@ Page Language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">

protected void Page_Load( object sender, EventArgs e )
{
if (!Page.IsPostBack)
{
string[] a = { "天气", "B", "C"};
CheckBoxList1.DataSource = a;
CheckBoxList1.DataBind();
for (int i = 0 ; i < CheckBoxList1.Items.Count ; i++)
{
if (CheckBoxList1.Items[i].Text == "天气")
{
CheckBoxList1.Items[i].Attributes.Add("onclick", "document.getElementById('" + DropDownList1.ClientID + "').style.display='none'");
}
else
{
CheckBoxList1.Items[i].Attributes.Add("onclick", "document.getElementById('" + DropDownList1.ClientID + "').style.display=''");
}

}
}
}
</script>

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>无标题页</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:CheckBoxList ID="CheckBoxList1" runat="server" AutoPostBack="false">
</asp:CheckBoxList></div>
<asp:DropDownList ID="DropDownList1" runat="server">
</asp:DropDownList>
</form>
</body>
</html>
加载更多回复(7)

62,072

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧