gpt4 book ai didi

c# - 绑定(bind) RowCommand 以在单击一行中的任何单元格时触发

转载 作者:行者123 更新时间:2023-11-30 15:02:11 27 4
gpt4 key购买 nike

我的 GridView 基本上显示数据库中数据的汇总版本。

我想做的是设置它,以便当您单击 GridView 中一行中的任意位置时,它应该执行一个设置过程,该过程将隐藏包含 GridView 的面板并显示一个面板,该面板将向您显示您点击的项目的详细信息。

        <asp:Panel runat="server" ID="pnlList">
<div class="rightalign">
<asp:Label runat="server" ID="lblCount"></asp:Label>
</div>

<asp:GridView runat="server" ID="gvItems" DataKeyNames="mailid"
AutoGenerateColumns="false" onrowdatabound="gvItems_RowDataBound"
Width="100%" OnSelectedIndexChanged="gvItems_SelectedIndexChanged">
<Columns>
<asp:TemplateField>
<ItemTemplate>
<asp:CheckBox runat="server" ID="chkSelect" />
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField>
<ItemTemplate>
<asp:Label runat="server" ID="lblStatus" Text='<%# DataBinder.Eval(Container.DataItem, "status") %>'></asp:Label>
</ItemTemplate>
</asp:TemplateField>
<asp:BoundField DataField="firstname" HeaderText="From" SortExpression="firstname" />
<asp:BoundField DataField="datesent" HeaderText="Date" SortExpression="datesent" DataFormatString="{0:yyyy/MM/dd HH:mm}" />
<asp:BoundField DataField="subject" HeaderText="Subject" SortExpression="subject" />
</Columns>
</asp:GridView>
</asp:Panel>

<asp:Panel runat="server" ID="pnlMail">
<p>From: <asp:Label runat="server" ID="lblFrom"></asp:Label><br />
Sent On: <asp:Label runat="server" ID="lblDate"></asp:Label><br />
Subject: <asp:Label runat="server" ID="lblSubject"></asp:Label></p>
<p><asp:Label runat="server" ID="lblMessage"></asp:Label></p>
</asp:Panel>

我想我会使用 SelectedIndexChanged 事件,但我不确定如何让它触发对单元格的点击。

这是我得到的代码:

    protected void gvItems_SelectedIndexChanged(object sender, EventArgs e)
{
int index = gvItems.SelectedIndex;

string mailid = gvItems.DataKeys[index].Value.ToString();

getMailDetail(mailid);
pnlMail.Visible = true;
}

protected void getMailDetail(string id)
{
int mailid = int.Parse(id);
MySqlContext db = new MySqlContext();

string sql = "select m.datesent, m.subject, m.message, u.firstname, u.lastname from mail m inner join users u on m.senderid = u.userid where m.mailid = @id";

List<MySqlParameter> args = new List<MySqlParameter>();
args.Add(new MySqlParameter() { ParameterName = "@id", MySqlDbType = MySqlDbType.Int32, Value = mailid });

MySqlDataReader dr = db.getReader(sql, args);

if (dr.HasRows)
{
dr.Read();

lblFrom.Text = (string)dr["firstname"] + " " + (string)dr["lastname"];
lblDate.Text = (string)dr["datesent"];
lblSubject.Text = (string)dr["subject"];
lblMessage.Text = (string)dr["message"];
}
dr.Close();
}

我怎样才能点击一行中的单元格来触发一个事件来完成我需要完成的工作?

任何帮助将不胜感激!

最佳答案

我可以在这里看到两种可能的解决方案。首先 - 在客户端处理点击行,将 Ajax 请求发送到一些 HttpHandler,它将返回您必要的邮件详细信息,并显示返回的信息。实现这一目标的步骤:

为点击行分配一个客户端处理程序:

protected void gvItems_RowDataBound(object sender, GridViewRowEventArgs e)
{
if(e.Row.RowType == DataControlRowType.DataRow)
{
e.Row.Attributes["onClick"] = "showMailDetails(" + DataBinder.Eval(e.Row.DataItem, "id") + ")";
}
}

并定义客户端函数:

function showMailDetails(mailId) {
$.get(
url: 'url to HttpHandler here',
data: {id: mailId},
success: function(data) {
var pnlMail = $('#<%= pnlMail.ClientID %>');
// display data here

pnlMail.show()
});
}

另一种方法是在客户端处理点击,然后通过执行以下操作来模拟 RowCommand 事件:

protected void gvItems_RowDataBound(object sender, GridViewRowEventArgs e)
{
if(e.Row.RowType == DataControlRowType.DataRow)
{
e.Row.Attributes["onClick"] = ""javascript:__doPostBack('" + gvItems.ClientID + "','MailDetailsCommand$" + DataBinder.Eval(e.Row.DataItem, "id") + "')";
}
}

然后在服务器端像你已经做的那样,只是在 RowComamnd 处理程序中:

protected void gvItems_RowCommand(object sender, GridViewCommandEventArgs e)
{
if (e.CommandName == "MailDetailsCommand") {
// ...
}
}

虽然我不推荐这种方法 - 手动使用 _doPostBack 不被认为是最佳实践。

关于c# - 绑定(bind) RowCommand 以在单击一行中的任何单元格时触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12930476/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com