时间:2021-07-01 10:21:17 帮助过:19人阅读
/// <summary>
/// 获取新闻数据列表
/// </summary>
/// <param name="num">请求数量</param>
/// <param name="cateId">类别ID</param>
/// <param name="isTop">是否置顶</param>
/// <param name="isCommend">是否推荐</param>
/// <returns>一个新闻数据集,News是新闻,当然,List<XXXX>名称取决于你的数据源</returns>
protected List<News> GetNewsData(int num,int cateId,int isTop,int isCommend){
if (num < 0) num = 0;
List<News> result = new List<News>();
Expression<Func<News, bool>> expr = PredicateExtensionses.True<News>();
if (isPic) {
expr = expr.And(c => c.IsPic == 1);
}
if (cateId > 0) {
expr = expr.And(c => c.cateId == cateId);
}
if (isTop > -1) {
expr = expr.And(c => c.IsTop == isTop);
}
if (isCommend > -1) {
expr = expr.And(c => c.IsCommend == isCommend);
}
return nm.AllNews.Where(expr).OrderByDescending(c=>c.ID).Take(num).ToList();
}
第二步:在Page_Load方法中,调用DataBind();
代码如下:
protected void Page_Load(object sender, EventArgs e)
{
DataBind();
}
以上是我方法的全部,这里要说一下的是调用业务逻辑中一个创建表达式树的公共类,这个类在这里(//www.gxlcms.com/article/28043.htm ),及通用业务逻辑类;
第三步,接下来是我们的aspx调用了.这里我用最简单的Repeater来说明!
代码如下:
<asp:Repeater ID="Repeater6" runat="server" DataSource='<%#GetNewsData(10,3548,-1,-1)%>'>
<ItemTemplate>
<%#Eval("Subject")%>
</ItemTemplate>
</asp:Repeater>
好了,所有工作结束.以后要调用其它的类别,或者数量要改变时,只需要在页面上改动就行了,不需要改动.cs和编译!
是不是挺方便?
关于DataBind()的说明,为什么要在Page_load中写DataBind(),这是提前给数据源以数据!否则,因为后期绑定的关系,会令到数据控件找不到数据源而报错!