C# 如何在asp.net中单击gridview上的标题文本时对gridview进行排序
我开发了一个具有Gridview控件的asp.net应用程序。我希望在asp.net中单击Gridview标题文本时对其进行排序。实体框架用于绑定gridviewC# 如何在asp.net中单击gridview上的标题文本时对gridview进行排序,c#,asp.net,entity-framework-4,C#,Asp.net,Entity Framework 4,我开发了一个具有Gridview控件的asp.net应用程序。我希望在asp.net中单击Gridview标题文本时对其进行排序。实体框架用于绑定gridview protected void grdmortgagesaver_Sorting(object sender, GridViewSortEventArgs e) { string sortExpression = e.SortExpression; if (GridViewSortDirection == SortDi
protected void grdmortgagesaver_Sorting(object sender, GridViewSortEventArgs e)
{
string sortExpression = e.SortExpression;
if (GridViewSortDirection == SortDirection.Ascending)
{
GridViewSortDirection = SortDirection.Descending;
SortGridView(sortExpression, DESCENDING);
}
else
{
GridViewSortDirection = SortDirection.Ascending;
SortGridView(sortExpression, ASCENDING);
}
}
private void SortGridView(string sortExpression, string direction)
{
// You can cache the DataTable for improving performance
var databind = from i in mortgageentites.Clients orderby i.LastName select i;
if (databind.Count() > 0)
{
grdmortgagesaver.DataSource = databind.ToList();
grdmortgagesaver.DataBind();
DataTable dt = clients;
if (dt != null)
{
// DataTable dt = ds.Tables[0];
DataView dv = new DataView(dt);
dv.Sort = sortExpression + direction;
grdmortgagesaver.DataSource = dv;
grdmortgagesaver.DataBind();
}
}
}
如果您使用的是标准的ASP.NET System.Web.UI.WebControl.GridView,您可以在属性窗格中通过将“AllowSorting”设置为true来简单地“启用排序”,或者通过控件右上角的“弹出窗口”,在GridView声明标记的页面中首先选中“启用排序”添加属性
AllowSorting=“true”
并在Gridview\u sort命令中尝试以下代码作为指导
try {
if (SortType == false) {
SortView.Sort = e.SortExpression + " ASC";
//dviewGeneral.Sort = e.SortExpression & " ASC"
Session.Item("SortOrder") = SortView.Sort.ToString;
SortType = true;
} else {
SortView.Sort = e.SortExpression + " DESC";
Session.Item("SortOrder") = SortView.Sort.ToString;
//dviewGeneral.Sort = e.SortExpression & " DESC"
SortType = false;
}
CMSgrid.SelectedIndex = -1;
CMSgrid.CurrentPageIndex = 0;
SortBind();
} catch (Exception ex) {
UserMsgBox(ex.ToString());
}
在gridview控件中添加AllowSorting=“true”,然后
protected void grd_Sorting(object sender, GridViewSortEventArgs e)
{
if (e.SortExpression == hdfSortExp.Value)
{
if (hdfUpDown.Value == "1")
hdfUpDown.Value = "0";
else
hdfUpDown.Value = "1";
}
else //New Column clicked so the default sort direction will be incorporated
hdfUpDown.Value = "0";
hdfSortExp.Value = e.SortExpression; //Update the sort column
BindGrid(hdfSortExp.Value, this.CBool(hdfUpDown.Value));
}
在你的c代码里
嗨,我已经发布了我的代码我做了什么排序。。。我使用的是普通asp.NET我不需要自定义排序,只是我已经尝试过这样做来获得结果。是否有其他排序顺序请帮助我Hi感谢您给出响应我想将我的tolist数据绑定到数据集我该怎么做。请帮助我。创建一个dataview变量并将数据集表分配给此视图,如ds.table[0]。defaultview;然后你可以调用dataview.sort()函数。首先,我不明白如何在sqlserver中使用实体框架将列表值分配给数据集。我可以。但是使用EF我可以如何做请帮助我。。
public void BindGrid(string sortBy, bool inAsc)
{
grd.DataSource = WManager.GetAdminTags(txtSearch.Text.Trim(), sortBy, inAsc);
grd.DataBind();
}