asp.net c# 中怎样利用JavaScript使gridview中的checkbox被全部选中?

在gridview中添加了模板列checkbox,怎样利用JavaScript使checkbox被全部选中或全部取消选中?请高手赐教!!... 在gridview中添加了模板列checkbox,怎样利用JavaScript使checkbox被全部选中或全部取消选中?请高手赐教!! 展开
 我来答
好片每日推荐
2008-10-28 · TA获得超过666个赞
知道小有建树答主
回答量:439
采纳率:0%
帮助的人:363万
展开全部
点评一下,1楼的不能用,3楼的可以用,但是操作的是静态的checkbox..
楼主有没有发现,例如ID为GridView1的数据表在用VS运行后变成HTML码后,
所有模板列中 runat="server"的CheckBox都被自动添加了Name和ID,但是这些ID和NAME是有规律的,例如. GridView1里的<ItemTemplate><asp:CheckBox ID="CheckBox1" runat="server" autopostback="false />,生成HTML后你可以看到,CheckBox1的ID变成了 GridView1_ctl02_CheckBox1(索引从02开始的,固定规律),然后03,04........所以可以用我下面的土方法来全选..假设你的GridView的ID是GridView1

function grcheckalll(obj)
{
var rowcount=document.getElementById("GridView1").rows.length;
for(var a=2;a<=rowcount+1;a++)
{
if(a>=10)
{var ckid="GridView1_ctl&_CheckBox1";
}
else
{var ckid="GridView1_ctl0&_CheckBox1";}
var aa=ckid.replace("&",a);
var bb=document.getElementById(aa);
if(bb!=null)
{
bb.checked=obj;
}
}
}
<TemplateField>
<headerTemplate>
<input type=checkbox value="" onclick="grcheckalll(this.checked)" title="全选">
<ItemTemplate>
<asp:CheckBox ID="CheckBox1" runat="server">
</ItemTemplate>
zhaochunyu0104
2008-10-27 · 超过14用户采纳过TA的回答
知道答主
回答量:47
采纳率:0%
帮助的人:29.1万
展开全部
<%@ Page 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">
<title>无标题页</title>
<script type="text/javascript">
function CheckAll()
{
var selects= document.getElementsByName("ContentIDs");
for(var i=0;i<selects.length;i++){
if(!selects[i].checked){
selects[i].click();
}
}
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False">
<Columns>
<asp:TemplateField>
<HeaderTemplate>
<nobr><a href="javascript:CheckAll();">全选</a></nobr>
</HeaderTemplate>
<ItemTemplate>
<input id="CheckboxSelect<%# Eval("r1") %>" type="checkbox" name="ContentIDs" value="<%# Eval("r2") %>" />
</ItemTemplate>
<ItemStyle HorizontalAlign="Center" />
<HeaderStyle Width="5%" />
</asp:TemplateField>
<asp:TemplateField HeaderText="标题" HeaderStyle-HorizontalAlign="Left">
<ItemTemplate>
<a onclick="event.cancelBubble=true;" href="View.aspx?ContentID=<%# Eval("r1") %>" target="_blank" title="<%# Eval("r2") %>"><%# Eval("r2")%></a>
</ItemTemplate>
<HeaderStyle Width="55%" />
</asp:TemplateField>
</Columns>
<PagerStyle CssClass="PagePanel" />
<PagerSettings Mode="NumericFirstLast" />
</asp:GridView>
</div>

</form>
</body>
</html>
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
fgh0302
2008-10-28 · TA获得超过238个赞
知道小有建树答主
回答量:423
采纳率:100%
帮助的人:230万
展开全部
// 判断多选是否与选中项(没有选中的返回false)
function slcNo_click()
{
if (document.form1.checkboxname.length)
{
for (var i=0;i<document.form1.checkboxname.length;i++)
{
if(document.form1.checkboxname[i].checked)
{
return true;
}
}
}
else
{
if(document.form1.checkboxname.checked)
{
return true;
}
}
alert("请选择后再操作!");
return false;
}
// 多选的全选与取消
function checkJs(boolvalue)
{
if(document.all.checkboxname.length>1)
{
for(var i=0;i<document.all.checkboxname.length;i++)
{
document.all.checkboxname[i].checked = boolvalue;
}
}
else
document.all.checkboxname.checked = boolvalue;
}
//

// 只有全部选中时“全选”选中
function SingleCheckJs()
{
var flag1=false;
var flag2=false;

if (document.form1.checkboxname.length)
{
for (var i=0;i<document.form1.checkboxname.length;i++)
{
if(document.form1.checkboxname[i].checked)
flag1 = true;
else
flag2 = true;
}
}
else
{
if(document.form1.checkboxname.checked)
flag1 = true;
else
flag2 = true;
}

if(flag1==true&&flag2==false)
document.getElementById("chk").checked = true;
else
document.getElementById("chk").checked = false;
}
<asp:TemplateField HeaderText="<input type='checkbox' id='chk' name='chk' onclick='checkJs(this.checked);' />全选" FooterText="全选">
<ItemTemplate>
<input type="checkbox" id="checkboxname" name="checkboxname" value='<%# DataBinder.Eval(Container.DataItem, "id")%>' onclick='SingleCheckJs();' />
</ItemTemplate>
</asp:TemplateField>
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
meteortent
2008-10-27 · TA获得超过518个赞
知道小有建树答主
回答量:870
采纳率:0%
帮助的人:732万
展开全部
<script language="javascript" type="text/javascript">
function select_all()
{
if(document.aspnetForm.List.checked==true)
{
for (var i = 0; i < aspnetForm.elements.length; i ++)
{
var e = aspnetForm.elements[i];e.checked = true;
}
}
else
{
for (var i = 0; i < aspnetForm.elements.length; i ++)
{
var e = aspnetForm.elements[i];e.checked = false;
}
}

}
</script>

<ItemTemplate >
<asp:CheckBox ID="CheckBox1" runat="server" />
</ItemTemplate>
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
功成有余香3912
2008-10-27 · TA获得超过130个赞
知道小有建树答主
回答量:581
采纳率:0%
帮助的人:279万
展开全部
1楼的差不多吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式