首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >检查是否至少选择了一个检查框列表

检查是否至少选择了一个检查框列表
EN

Stack Overflow用户
提问于 2013-03-06 23:36:00
回答 9查看 30.3K关注 0票数 9

我有checkboxlist,我想检查是否至少选中了一个复选框。如果未选中,则我希望显示警告消息,提示请至少选择一个项目。如果可能的话,我想在后台代码中做这件事。我已经开始了,但不知道它是对还是错,但无法完成它。

代码语言:javascript
运行
复制
 public void alert()
    {
        foreach (ListItem listItem in cblCustomerList.Items)
        {
            if (!listItem.Selected)
            {
            }
        }
    }

以下是aspx中的检查框列表:

代码语言:javascript
运行
复制
 <asp:CheckBoxList ID="cblCustomerList" runat="server" DataSourceID="SqlDataSource1" CssClass="CheckBoxList"
            DataTextField="GroupName" DataValueField="GroupName" 
                onclick="readCheckBoxList()" >               
            </asp:CheckBoxList>

这是按钮:

代码语言:javascript
运行
复制
 <asp:Button ID="Button1" runat="server" CausesValidation="True" 
                            CommandName="Insert" Text="Insert" OnClientClick="return Validate_Checkbox()" />

谢谢你的帮助。

EN

回答 9

Stack Overflow用户

回答已采纳

发布于 2013-03-06 23:39:44

编辑:

下面是一个示例代码。这对我很有效

必须添加此脚本文件:<script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>

代码语言:javascript
运行
复制
 <%@ 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 src="//ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
    <script type="text/javascript">
        function Validate_Checkbox() {
            var chks = $("#<%= cblCustomerList.ClientID %> input:checkbox");          

            var hasChecked = false;
            for (var i = 0; i < chks.length; i++) {
                if (chks[i].checked) {
                    hasChecked = true;
                    break;
                }
            }
            if (hasChecked == false) {
                alert("Please select at least one checkbox..!");

                return false;
            }

            return true;
        }     
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:CheckBoxList ID="cblCustomerList" runat="server" CssClass="CheckBoxList">
            <asp:ListItem Value="0">xx</asp:ListItem>
            <asp:ListItem Value="1">yy</asp:ListItem>
        </asp:CheckBoxList>
        <asp:Button ID="xx" runat="server" OnClientClick="javascript:Validate_Checkbox();return true;" />
    </div>
    </form>
</body>
</html>

而你改变了

代码语言:javascript
运行
复制
<asp:CheckBoxList ID="cblCustomerList" runat="server" DataSourceID="SqlDataSource1" CssClass="CheckBoxList" DataTextField="GroupName" DataValueField="GroupName">             
            </asp:CheckBoxList>

控件,而不是我的示例代码。并在按钮control.look中调用我的示例代码中的javascript function

切尔斯!

编辑

请添加此脚本文件

代码语言:javascript
运行
复制
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>

代替<script src="scripts/jquery-1.8.3.min.js" type="text/javascript"></script>

票数 8
EN

Stack Overflow用户

发布于 2013-03-06 23:37:56

代码语言:javascript
运行
复制
if(cblCustomerList.Items.Cast<ListItem>().Any(item => item.Selected))
{
   // at least one selected
}
票数 11
EN

Stack Overflow用户

发布于 2013-03-06 23:38:40

试试这个;

代码语言:javascript
运行
复制
boolean b = cblCustomerList.Items.Cast<ListItem>().Any(i => i.Selected)

如果btrue,则在checkboxlist列表中至少选择了一个。

不要忘记使用System.Linq名称空间。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15251522

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档