单击按钮获取列值

时间:2018-09-14 08:40:21

标签: c# asp.net aspxgridview

我有几行表。每行前面都有一个“选择”按钮。 表格:

https://jsfiddle.net/qmg1309n/2/

表中填充了从数据库获取值的过程。 我在其中获取值并将其发送到aspx的C#部分:

LogicTableAdapters.getLevelTableAdapter getLvl = new LogicTableAdapters.getLevelTableAdapter();

DataTable dtLvl = getLvl.getLevel(Convert.ToInt32(ddlLevel.SelectedValue));

DataTable dt = new DataTable();
dt.Columns.AddRange(new DataColumn[4]{ new DataColumn("ObjtID", typeof(int)), new DataColumn("Name", typeof(string)), new DataColumn("BCC", typeof(string)),new DataColumn("ParentName", typeof(string))  ,});
foreach (DataRow dr in dtLvl.Rows)
{
    dt.Rows.Add(Convert.ToInt32(dr["ObjID"]), dr["Name"].ToString(), dr["BCC"].ToString(), dr["ParentName"].ToString());
}

gvObject.DataSource = dt;
gvObject.DataBind();

这是asp部分:

<asp:GridView ID="gvObject" runat="server" CellPadding="4" ForeColor="#333333" GridLines="None" AutoGenerateColumns="False" CssClass="GridView">

    <AlternatingRowStyle BackColor="White" />
    <Columns>
        <asp:TemplateField>
            <ItemTemplate>
                <button class="myBtn" type="button" data-toggle="modal" data-target="#myModal" style="vertical-align: middle"><span>Select</span></button>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="ObjID">
            <ItemTemplate>
                <asp:Label ID="ObjID" runat="server" class="ObjekatID" Width="118px" Height="36px" Style="text-align: center" Font-Names="Georgia" margin-Left="100px" Text='<%# Bind("ObjID") %>'></asp:Label>


            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="Name">
            <ItemTemplate>

                <asp:Label ID="Name" runat="server" Width="118px" Height="26px" Style="text-align: center" Font-Names="Georgia" margin-Left="100px" Text='<%# Bind("Name") %>'></asp:Label>

            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="BCC">
            <ItemTemplate>

                <asp:Label ID="BCC" runat="server" Width="118px" Height="26px" Style="text-align: center" Font-Names="Georgia" margin-Left="100px" Text='<%# Bind("BCC") %>'></asp:Label>

            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="ParentName">
            <ItemTemplate>

                <asp:Label ID="ParentName" runat="server" Width="118px" Height="26px" Style="text-align: center" Font-Names="Georgia" margin-Left="100px" Text='<%# Bind("ParentName") %>'></asp:Label>

            </ItemTemplate>
        </asp:TemplateField>
    </Columns>

</asp:GridView>

单击每行前面的“选择”按钮时,我需要仅获取该行的ObjID值并将其存储在C#中的变量中。

该ObjID值稍后将成为新的GET过程的参数,该过程将在单击选择按钮时生成新表。

有人可以帮我吗?

谢谢!

1 个答案:

答案 0 :(得分:1)

如果您在GridView中定义了OnSelectedIndexChanged事件,则可以使用该事件来查找SelectedRow的标签。

protected void GridView1_SelectedIndexChanged(object sender, EventArgs e)
{
    Label lbl = ((GridView)sender).SelectedRow.FindControl("ObjID") as Label;

    var ObjID = lbl.Text;
}

aspx

<asp:GridView ID="GridView1" runat="server" AutoGenerateSelectButton="true" 
    OnSelectedIndexChanged="GridView1_SelectedIndexChanged">

更新

如果仅在前端需要,则可以执行此操作。将数据属性添加到按钮。

<button class="myBtn" type="button" data-objid="<%# Eval("ObjID") %>">

然后,当单击按钮时,您可以读取该属性并获取值。

<script type="text/javascript">
    $('.myBtn').click(function () {
        alert($(this).data('objid'));
    });
</script>