C# 中的DataGridView控件如何设置成具有复选框功能?

如下图左边的复选框:... 如下图左边的复选框: 展开
 我来答
百度网友9463fa8
推荐于2018-09-27 · TA获得超过164个赞
知道小有建树答主
回答量:257
采纳率:100%
帮助的人:122万
展开全部
<Columns>
<asp:TemplateColumn HeaderText="Checked" HeaderStyle-Width="30">
<HeaderTemplate>
<input id="chkAllInBox" type="checkbox" onclick="selectAll('chkAllInBox','<%# this.grdList.ClientID %>')" />
</HeaderTemplate>
<ItemTemplate>
<input type="checkbox" id="chids" value='<%# DataBinder.Eval(Container, "DataItem.ID") %>'
runat="server" name="chids" />
</ItemTemplate>
<HeaderStyle Width="30px"></HeaderStyle>
<ItemStyle Font-Bold="False" Font-Italic="False" Font-Overline="False" Font-Strikeout="False"
Font-Underline="False" HorizontalAlign="Center" />
</asp:TemplateColumn>
<asp:BoundColumn DataField="ID" SortExpression="ID" HeaderText="id" Visible="false">
</asp:BoundColumn>
<asp:BoundColumn DataField="EventCount" SortExpression="EventCount" HeaderText='数量'></asp:BoundColumn>
<asp:BoundColumn DataField="DomainName" HeaderText="类型" SortExpression="DomainName">
</asp:BoundColumn>
<asp:BoundColumn DataField="CalItemName" SortExpression="CalItemName" HeaderText="计算项">
</asp:BoundColumn>
<asp:BoundColumn DataField="CalUnitName" SortExpression="CalUnitName" HeaderText="地区或单位">
</asp:BoundColumn>
<asp:BoundColumn DataField="EventDesc" SortExpression="EventDesc" HeaderText="事件描述">
</asp:BoundColumn>
<asp:BoundColumn DataField="Month" SortExpression="Month" HeaderText="上报月份"></asp:BoundColumn>
<asp:BoundColumn DataField="DraftWriter" SortExpression="DraftWriter" HeaderText="填写人">
</asp:BoundColumn>
<asp:BoundColumn DataField="DraftWriteTime" SortExpression="DraftWriteTime" HeaderText="填写时间"
DataFormatString='{0:d}'></asp:BoundColumn>
<%--<asp:TemplateColumn>
<HeaderTemplate>
<asp:Label ID="lblPar1Name" runat="server"></asp:Label>
</HeaderTemplate>
<ItemTemplate>
<asp:Label ID="lblPar1" runat="server"></asp:Label>
</ItemTemplate>
</asp:TemplateColumn>
<asp:TemplateColumn>
<HeaderTemplate>
<asp:Label ID="lblPar2Name" runat="server"></asp:Label>
</HeaderTemplate>
<ItemTemplate>
<asp:Label ID="lblPar2" runat="server"></asp:Label>
</ItemTemplate>
</asp:TemplateColumn>
<asp:TemplateColumn>
<HeaderTemplate>
<asp:Label ID="lblPar3Name" runat="server"></asp:Label>
</HeaderTemplate>
<ItemTemplate>
<asp:Label ID="lblPar3" runat="server"></asp:Label>
</ItemTemplate>
</asp:TemplateColumn>--%>
<asp:BoundColumn DataField="Par1" SortExpression="Par1" HeaderText="批次" Visible="False">
</asp:BoundColumn>
<asp:BoundColumn DataField="Par2" SortExpression="Par2" HeaderText="Par2" Visible="False">
</asp:BoundColumn>
<asp:BoundColumn DataField="Par3" SortExpression="Par3" HeaderText="Par3" Visible="False">
</asp:BoundColumn>
<asp:TemplateColumn HeaderStyle-Width="40" ItemStyle-HorizontalAlign="Center" HeaderText="编辑">
<ItemTemplate>
<asp:HyperLink ID="hlkEditInfo" runat="server" ImageUrl="~/images/edit.gif" NavigateUrl='<%# EditUrl("ItemId",DataBinder.Eval(Container, "DataItem.ID").ToString(),"Edit") %>'></asp:HyperLink>
</ItemTemplate>
<HeaderStyle Width="40px"></HeaderStyle>
<ItemStyle HorizontalAlign="Center"></ItemStyle>
</asp:TemplateColumn>
<asp:TemplateColumn HeaderStyle-Width="40" ItemStyle-HorizontalAlign="Center" HeaderText="删除">
<ItemTemplate>
<asp:LinkButton runat="server" ID="lbnDelInfo" CommandName="CommandDelete" BorderStyle="None">
<asp:Image runat="server" ID="imgDelete" BorderStyle="None" ImageUrl="~\images\button_delete.gif"
ImageAlign="AbsMiddle"></asp:Image>
</asp:LinkButton>
</ItemTemplate>
<HeaderStyle Width="40px"></HeaderStyle>
<ItemStyle HorizontalAlign="Center"></ItemStyle>
</asp:TemplateColumn>
</Columns>

<script language="javascript">
//全选
function selectAll(SourceID, ControlID) {
var sourceBox = document.getElementById(SourceID);
var theBox = document.all(ControlID);

elm = theBox.getElementsByTagName('Input');
for (i = 0; i < elm.length; i++) {
if (elm[i].type == "checkbox") {
elm[i].checked = sourceBox.checked;
}
}
}
//选择删除检测
function CheckNULL(ControlID) {
var isNULL = false;
var theBox = document.all(ControlID);
elm = theBox.getElementsByTagName('Input');

for (var i = 0; i < elm.length; i++) {
var e = elm[i];
if (e.type == "checkbox" && e.checked == true && e.id != "chkAllInBox") {
isNULL = true;
}
}
if (isNULL == false) {
alert('请选择删除项!');
return false;
}
else {
return confirm('确定要删除信息?');
}
}
</script>
02p2uvkpb
2011-03-19 · TA获得超过1247个赞
知道小有建树答主
回答量:1433
采纳率:0%
帮助的人:895万
展开全部
checkbox控件。
方法1、为checkbox控件增加客户端点击事件,用JSON对象保存选中项目,在其他按钮提交的时候将该JSON对象转换写入LIST<T>集合中。优点:不需要每次都提交刷新页面。
方法2、将该checkbox设置:AutoPostBack=true。到后台代码检测点击的是哪一行,再进行你的LIST泛型对象的增加删除逻辑。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
卡卡亚索隆
推荐于2016-01-11 · 超过42用户采纳过TA的回答
知道小有建树答主
回答量:142
采纳率:0%
帮助的人:148万
展开全部
将你要显示成checkbox的column type直接改成DataGridViewCheckBoxColumn即可。
也可以在插入新column时可以直接设置。
追问
我是从数据库直接获取一张表绑定到DataGridView中,如何把整张表都设置成具有复选框功能?
追答
column的类型是不能被你以编程的形式动态的改变的。强制改变会抛出wrong type异常
你应该在导入数据的时候判断行列,然后建立CheckBoxColumn
---给你提供一种强制改变所有cell类型的方法---
for (int i = 0; i < dataGridView1.RowCount; i++)
{
for (int j = 0; j < dataGridView1.ColumnCount; j++)
{
dataGridView1.Rows[i].Cells[j] = new DataGridViewCheckBoxCell();
}
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式