展开全部
页面:在GridView的<column></column>中加入
<asp:TemplateField HeaderText ="选择">
<ItemTemplate >
<asp:CheckBox ID="CheckBox1" runat="server">
</asp:CheckBox>
</ItemTemplate>
<FooterTemplate>
<asp:CheckBox ID="CheckBox2" runat="server" OnCheckedChanged="CheckBox2_CheckedChanged" AutoPostBack="true">
</asp:CheckBox>
</FooterTemplate>
</asp:TemplateField>
后台CS:
protected void CheckBox2_CheckedChanged(object sender, EventArgs e)
{
CheckBox checkBox;
bool check = (GridView1.FooterRow.FindControl("CheckBox2") as CheckBox).Checked;
foreach (GridViewRow gridViewRow in GridView1.Rows)
{
checkBox = gridViewRow.FindControl("CheckBox1") as CheckBox;
checkBox.Checked = check;
}
}
<asp:TemplateField HeaderText ="选择">
<ItemTemplate >
<asp:CheckBox ID="CheckBox1" runat="server">
</asp:CheckBox>
</ItemTemplate>
<FooterTemplate>
<asp:CheckBox ID="CheckBox2" runat="server" OnCheckedChanged="CheckBox2_CheckedChanged" AutoPostBack="true">
</asp:CheckBox>
</FooterTemplate>
</asp:TemplateField>
后台CS:
protected void CheckBox2_CheckedChanged(object sender, EventArgs e)
{
CheckBox checkBox;
bool check = (GridView1.FooterRow.FindControl("CheckBox2") as CheckBox).Checked;
foreach (GridViewRow gridViewRow in GridView1.Rows)
{
checkBox = gridViewRow.FindControl("CheckBox1") as CheckBox;
checkBox.Checked = check;
}
}
展开全部
http://tech.163.com/06/1102/14/2UU9UL3S0009215D.html
这里有个视频 讲多项删除的时候 用到了全选 他是 放在头模板的 其实原来一样 就是在你的footer种的checkbox改变后 去遍历你gridview中的控件 然后给它们赋值就ok了
这里有个视频 讲多项删除的时候 用到了全选 他是 放在头模板的 其实原来一样 就是在你的footer种的checkbox改变后 去遍历你gridview中的控件 然后给它们赋值就ok了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
如果做全选操作,这些应该在客户端执行,以不造成服务端的压力.所以.这个功能咱们得用javascript来做.
使用这段脚本代码,需要GridView包含CheckBox的列为模板列.其中的CheckBox名称为"cb_Check"(名称可以改,不过也得修改代码里的).
javascript 代码如下:
<script type="text/javascript" defer="defer">
function CheckAll(checked) //传一个表单作参数
{
var form = document.getElementById("form1")
for (var i=0;i<form.elements.length;i++) //对这个表单里的元素进行循环
{
var e = form.elements[i]; //一个一个元素判断
if (e.name.indexOf("cb_Check") != 0 && e.disabled!=true) //如果该元素的name属性不为chkAll并且disabled!=true.即:该控件可用时
e.checked = checked; //控元素的checked与当前选中的控件checked保持一致.即:全选/全不选
}
}
</script>
在.cs页面给GridView的Footer中的CheckBox注册javascipt事件,这里的CheckBox的ID为"cb_CheckAll"
protected void Page_Load(object sender, System.EventArgs e)
{
CheckBox cb = gv_main.FooterRow.FindControl("cb_CheckAll");
if ((cb != null)) {
((CheckBox)cb).Attributes.Add("onclick", "CheckAll('" + cb.Checked.ToString() + "');");
}
}
看似很简单.搞定啦,试试吧.
使用这段脚本代码,需要GridView包含CheckBox的列为模板列.其中的CheckBox名称为"cb_Check"(名称可以改,不过也得修改代码里的).
javascript 代码如下:
<script type="text/javascript" defer="defer">
function CheckAll(checked) //传一个表单作参数
{
var form = document.getElementById("form1")
for (var i=0;i<form.elements.length;i++) //对这个表单里的元素进行循环
{
var e = form.elements[i]; //一个一个元素判断
if (e.name.indexOf("cb_Check") != 0 && e.disabled!=true) //如果该元素的name属性不为chkAll并且disabled!=true.即:该控件可用时
e.checked = checked; //控元素的checked与当前选中的控件checked保持一致.即:全选/全不选
}
}
</script>
在.cs页面给GridView的Footer中的CheckBox注册javascipt事件,这里的CheckBox的ID为"cb_CheckAll"
protected void Page_Load(object sender, System.EventArgs e)
{
CheckBox cb = gv_main.FooterRow.FindControl("cb_CheckAll");
if ((cb != null)) {
((CheckBox)cb).Attributes.Add("onclick", "CheckAll('" + cb.Checked.ToString() + "');");
}
}
看似很简单.搞定啦,试试吧.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询