我有一个 DevExpress gridview,我datasource
从 (c#) 后面的代码绑定到它。我的动作可以正常工作,但是当我使用rowfilter
它时却不行。
我认为向我发送信息的命令参数datasource
是错误的。
我在第 1 行的 id 是 1,我在第 13 行的 id 应该是 13 但是在第 13 行rowfilter
点击按钮(行命令)后,我的 id 发送到后面的代码(命令参数)是 1!
如何从一行中获取 ID(GridView Devexpress)?
我的网格视图:
<dx:ASPxGridView ID="gv" runat="server" AutoGenerateColumns="False" OnRowCommand="gv_RowCommand" OnDataBinding="gv_DataBinding"
ClientInstanceName="gv" KeyFieldName="Id"
Width="100%">
<Columns>
<dx:GridViewDataTextColumn Caption="" CellStyle-HorizontalAlign="Center" VisibleIndex="0" Width="12%">
<DataItemTemplate>
<asp:LinkButton ID="btnconfirm" Text="Print" Width="70px" CssClass="btn btn-primary btn-small" ForeColor="#cc0000" CommandArgument='<%# Eval("Id") %>'
CommandName="print" runat="server"
OnClientClick="return confirm('Print?');">
</asp:LinkButton>
</DataItemTemplate>
<HeaderStyle HorizontalAlign="center" />
</dx:GridViewDataTextColumn>
</Columns>
<SettingsPager PageSize="80">
</SettingsPager>
<Settings ShowFilterRow="true" />
</dx:ASPxGridView>
我的绑定代码:
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
refreshGrid();
gv.DataBind();
}
}
protected void gv_DataBinding(object sender, EventArgs e)
{
refreshGrid();
}
protected void gv_RowCommand(object sender, DevExpress.Web.ASPxGridView.ASPxGridViewRowCommandEventArgs e)
{
if (e.CommandArgs.CommandName == "print")
{
String _ID = e.CommandArgs.CommandArgument.ToString();
}
}
private void refreshGrid()
{
DataClasses1DataContext m = new DataClasses1DataContext();
var q = from p in m.TblUserElectronics.AsQueryable()
from w in m.ViewPersonCarRelations
where p.CID == w.CarId
select new
{
p.Id,
p.Enabled,
CodeTaxi = w.Code_Taxi
};
gv.DataSource = q;
}