【发布时间】:2014-02-22 20:20:32
【问题描述】:
我有一个GridView,第一列有CheckBox,第二列有Button。当用户点击Button 时,current row 的CheckBox 必须是Invisible,使用Javascript。
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" AllowPaging="true"
PageSize="100" AllowSorting="true" DataSourceID="sqlUsers" DataKeyNames="ttppcid"
Width="100%" OnRowCommand="GridView1_RowCommand" EmptyDataText="No Data Found"
OnPageIndexChanging="GridView1_PageIndexChanging" OnRowDataBound="GridView1_RowDataBound">
<Columns>
<asp:TemplateField ItemStyle-Width="30px" ItemStyle-HorizontalAlign="Center" HeaderStyle-HorizontalAlign="Center" Visible="true">
<ItemTemplate>
<asp:CheckBox ID="chkSelect" runat="server" Height="30" class="mychk" rowid="<%# Container.DataItemIndex+1 %>" />
</ItemTemplate>
</asp:TemplateField>
//some more templates here
<asp:TemplateField HeaderText="" ItemStyle-Width="70px" ItemStyle-HorizontalAlign="Center"
HeaderStyle-HorizontalAlign="Center">
<ItemTemplate>
<asp:Button ID="BtnSource" runat="server" Text="Source" rowid="<%# Container.DataItemIndex+1 %>"
class="showButton" OnClick='<%# "return SetRowValues("+Eval("ttppcid")+",this.id,"+Eval("Fair")+","+Eval("Good")+","+Eval("Mint")+","+Eval("Poor")+","+Eval("Fair")+")"%>' />
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
Javascript:
function SetRowValues(id, controlid, fair, good, mint, nnew, poor, broken) {
var rowid = $("#" + controlid).attr("rowid");
var chkBoxID;
var chkRowid;
$('.mychk').css("display", "block");
$('.mychk').each(function() {
chkBoxID = this.id;
alert(chkBoxID);
chkRowid = $("#" + chkBoxID).attr("rowid");
alert(chkBoxID + " ROW :" + chkRowid);
if (chkRowid == rowid) {
$("#" + chkBoxID).css("display", "none");
}
else {
$("#" + chkBoxID).css("display", "block");
}
});
return false;
}
在alert 中一切正常,我得到了空。无法获取 CheckBox 控件的 ID
也试过了:
<script type="text/javascript">
$(document).ready(function() {
$(function() {
$(".showButton").on("click", function() {
alert(".showButton clicked");
$(this).closest("tr").find(":checkbox").hide();
});
});
});
</script>
渲染的复选框:
<td align="center" style="width: 30px; display: block;">
<span class="mychk" rowid="1" style="display: block; height: 30px;"><input id="ctl00_ContentPlaceHolder1_GridView1_ctl02_chkSelect" type="checkbox" name="ctl00$ContentPlaceHolder1$GridView1$ctl02$chkSelect"></span>
</td>
网格中的渲染按钮:
<td align="center" style="width: 70px; display: block;">
<input type="submit" name="ctl00$ContentPlaceHolder1$GridView1$ctl03$BtnSource" value="Source" onclick="return SetRowValues(6,this.id,222.0000,222.0000,222.0000,222.0000,222.0000);WebForm_DoPostBackWithOptions(new WebForm_PostBackOptions("ctl00$ContentPlaceHolder1$GridView1$ctl03$BtnSource", "", true, "", "", false, false))" id="ctl00_ContentPlaceHolder1_GridView1_ctl03_BtnSource" class="showButton" rowid="1" style="">
</td>
有什么想法吗?
帮助赞赏!
【问题讨论】:
-
运行应用程序后最终的 html 是什么?你能粘贴html输出吗?
-
如果我理解正确,您无法使用 javascript 实现这一点。 asp 按钮将进行回发,隐藏的复选框将再次可见。如果您不想进行回发,请使用 html-button。
-
@Rahat 请检查编辑..!
-
嗨@Esa,它们不是回发,因为我的返回语句总是返回“假”。一切正常,因为我只需要无法隐藏复选框。
-
您使用的是服务器端的 OnClick-property,您是指 OnClientClick 吗?无论如何,如果您不想回发,请首先不要使用 asp-button。
标签: javascript jquery gridview checkbox