我有一个场景,我在Gridview
中显示数据。现在我想要的是,有两个按钮,分别为Approve
和Reject
。我想验证在单击buttons
之一之前,应至少选中一个复选框。
下面是我的HTML。
<asp:GridView ID="grdDisplayCMMData" runat="server" AutoGenerateColumns="false" Width="100%" ShowHeaderWhenEmpty="true" CssClass="heavyTable table" EmptyDataText="No records to display"
AllowPaging="true" PageSize="20" OnPageIndexChanging="grdDisplayCMMData_PageIndexChanging">
<Columns>
<asp:BoundField DataField="ID" HeaderText="Id" ItemStyle-Width="10%" />
<asp:BoundField DataField="SAP_ID" HeaderText="Sap Id" ItemStyle-Width="10%" />
<%--<asp:BoundField DataField="ID_OD" HeaderText="ID to OD" ItemStyle-Width="10%" />--%>
<asp:BoundField DataField="ID_OD_COUNTCHANGE" HeaderText="ID to OD Change" ItemStyle-Width="10%" />
<asp:BoundField DataField="ID_OD_CHANGEDDATE" HeaderText="ID to OD Change Date" ItemStyle-Width="10%" />
<asp:BoundField DataField="RRH_COUNTCHANGE" HeaderText="RRH Count Change" ItemStyle-Width="10%" />
<asp:BoundField DataField="RRH_CHANGEDDATE" HeaderText="RRH Count Change Date" ItemStyle-Width="10%" />
<asp:BoundField DataField="TENANCY_COUNTCHANGE" HeaderText="Tenancy Count Change" ItemStyle-Width="10%" />
<asp:BoundField DataField="TENANCY_CHANGEDDATE" HeaderText="Tenancy Changed Date" ItemStyle-Width="10%" />
<asp:BoundField DataField="STATUS" HeaderText="Current Status" ItemStyle-Width="20%" />
<asp:TemplateField HeaderText="Approve/Reject">
<ItemTemplate>
<asp:CheckBox ID="chkApprRejCMM" runat="server" />
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
<div class="text-center">
<asp:Button ID="btnApproveCMM" Text="Approve" runat="server" OnClick="btnApproveCMM_Click" CssClass="btn btn-primary" />
<asp:Button ID="btnRejectCMM" Text="Reject" runat="server" OnClick="btnRejectCMM_Click" CssClass="btn btn-primary" />
</div>
另请参阅我的OnClick
批准事件。
protected void btnApproveCMM_Click(object sender, EventArgs e)
{
try
{
IPColoFields ObjIPColoFields = new App_Code.IPColoFields();
List<IPColoBilling.App_Code.UMS.UMSGroupDetails> UMSGroupDetails = (List<IPColoBilling.App_Code.UMS.UMSGroupDetails>)Session["lstUMSGroupDetails"];
Session["lstUMSGroupDetails"] = UMSGroupDetails;
string strApprove = "";
foreach (GridViewRow gvrow in grdDisplayCMMData.Rows)
{
var checkbox = gvrow.FindControl("chkApprRejCMM") as CheckBox;
if (checkbox.Checked)
{
int Id = Convert.ToInt32(grdDisplayCMMData.Rows[gvrow.RowIndex].Cells[0].Text);
ObjIPColoFields.Unique_Id = Id;
ObjIPColoFields.UMS_GRP_BY_ID = intCurrentGrpId;
ObjIPColoFields.UMS_GRP_BY_NAME = strCurrentGrp;
ObjIPColoFields.UMS_GRP_TO_ID = UMSGroupDetails[1].GroupID;
ObjIPColoFields.UMS_GRP_TO_NAME = UMSGroupDetails[1].GroupName;
ObjIPColoFields.FCA_STATUS = "1";
ObjIPColoFields.LAST_UPDATED_BY = lblUserName.Text;
strApprove = CommonDB.Approve_IPCOLO_CMMLevel(ObjIPColoFields);
}
}
ScriptManager.RegisterStartupScript(this, this.GetType(), "alert", "alert('Record Approved successfully'); window.location ='IpColoDefault.aspx';", true);
BindCMMData();
}
catch (Exception ex)
{
string strErrorMsg = ex.Message.ToString() + " " + "StackTrace :" + ex.StackTrace.ToString();
CommonDB.WriteLog("ERROR:" + strErrorMsg, ConfigurationManager.AppSettings["IPCOLO_LOG"].ToString());
}
}
我尝试了获取复选框计数的逻辑,如果该计数小于0
,则提示错误。但是在Checkbox中没有获得计数的这种属性。
请提出其他建议
答案 0 :(得分:1)
您可以使用CustomValidator进行此操作。
<asp:CustomValidator ID="CustomValidator1" runat="server" ClientValidationFunction="countCheckBoxes"
ErrorMessage="Check at least one"></asp:CustomValidator>
然后是用于测试是否选中任何复选框的功能。
<script type="text/javascript">
function countCheckBoxes(oSrc, args) {
var cnt = $('<%# GridView1.ClientID %> input[type=checkbox]:checked').length;
args.IsValid = cnt > 0;
}
</script>
答案 1 :(得分:0)
您可以按照以下步骤操作。
<asp:CheckBox ID="chkApprRejCMM" runat="server" Class="xyz" />
2。将OnClientClick事件添加到按钮
> <asp:Button ID="btnApproveCMM" Text="Approve" runat="server"
> OnClick="btnApproveCMM_Click" CssClass="btn btn-primary" OnClientClick
> = "javascript:return CheckData(); " />
3。使用Jquery检查是否至少选中了一个复选框,如果在CheckData函数中选择了non,则返回false。
`
` if($('input.xyz:checked').length> 0){返回false;}否则返回true;
`
` 如果函数返回false,则不会发生回发。