利用JavaScript使gridview中的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="" οnclick="grcheckalll(this.checked)" title="全选">
<ItemTemplate>
<asp:CheckBox ID="CheckBox1" runat="server">
</ItemTemplate>

 

 

 

其他回答     4
<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>
回答者: meteortent - 试用期 一级   offline.gif 10-27 22:39
1楼的差不多吧
回答者: xucheng_1 - 见习魔法师 三级   offline.gif 10-27 23:01
<%@ 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 οnclick="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>
回答者: zhaochunyu0104 - 经理 四级   offline.gif 10-27 23:25
// 判断多选是否与选中项(没有选中的返回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' οnclick='checkJs(this.checked);' />全选" FooterText="全选">
<ItemTemplate>
<input type="checkbox" id="checkboxname" name="checkboxname" value='<%# DataBinder.Eval(Container.DataItem, "id")%>' οnclick='SingleCheckJs();' />
</ItemTemplate>
</asp:TemplateField>
回答者: fgh0302 - 秀才 三级   offline.gif 10-28 08:22

转载于:https://www.cnblogs.com/lhuser/articles/1467227.html

Python网络爬虫与推荐算法新闻推荐平台:网络爬虫:通过Python实现新浪新闻的爬取,可爬取新闻页面上的标题、文本、图片、视频链接(保留排版) 推荐算法:权重衰减+标签推荐+区域推荐+热点推荐.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计,皆可应用在项目、毕业设计、课程设计、期末/期/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值