DataBinder.Eval总结

 

一、DataBinder.Eval的基本格式

在绑定数据时经常会用到这个句程序:<%# DataBinder.Eval(Container.DataItem,"xxxx")%>

或者<%# DataBinder.Eval(Container,"DataItem.xxxx")%>

 

今天又学到一种,而且微软也说这种方法的效率要比以上两种高。

<%# ((DataRowView)Container.DataItem)["xxxx"]%>

很有用的,这样可以在前台页面做好多事情了。

还要记住要这样用必须要在前台页面导入名称空间System.Data,否则会生成错误信息。

<%@ Import namespace="System.Data" %>

这种用法其实和<%# ((DictionaryEntry)Container.DataItem).Key%>是一个道理。

Text='<%# DataBinder.Eval(Container.DataItem, "字段") %>'
这样的方法是最快的

Text='<%# GetPrice() %>'
也可以绑定方法,但方法要是public的

Text='<%# "CarDetails.aspx?CarID=" + DataBinder.Eval(Container.DataItem, "CarID") %>'
还可以连接多个字段

关键是Container这个东西,它比较神秘。它的名称空间是System.ComponentModel。对于它我还需要进一步理解。

二、DataBinder.Eval实现判断选择
<asp:TemplateColumn HeaderText="性别">
<ItemTemplate>
<%# DGFormatSex(Convert.ToString(DataBinder.Eval(Container.DataItem,"xb"))) %>
</ItemTemplate>
</asp:TemplateColumn>

cs里定义DGFormatSex方法
protected string DGFormatSex(string xb)
{
if(xb == "1")
return "男";
else
return "女";
}

DataBinder.Eval用法范例
DataBinder.Eval用法范例

//显示二位小数
//<%# DataBinder.Eval(Container.DataItem, "UnitPrice", "${0:F2}") %>

//{0:G}代表显示True或False
//<ItemTemplate>
// <asp:Image Width="12" Height="12" Border="0" runat="server"
// AlternateText='<%# DataBinder.Eval(Container.DataItem, "Discontinued", "{0:G}") %>'
// ImageUrl='<%# DataBinder.Eval(Container.DataItem, "Discontinued", "~/images/{0:G}.gif") %>' />
// </ItemTemplate>

//转换类型
((string)DataBinder.Eval(Container, "DataItem.P_SHIP_TIME_SBM8")).Substring(4,4)

{0:d} 日期只显示年月日
{0:yyyy-mm-dd} 按格式显示年
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要改变GridView中行的颜色,您可以使用CSS样式或在后端代码中设置行的样式。 1. 使用CSS样式: 在CSS文件中定义一个类来设置行的样式,例如: ```css .highlight-row { background-color: red; // 设置背景颜色为红色 } ``` 然后,在GridView中的RowDataBound事件中,为符合条件的行添加该CSS类名。在代码-behind文件中: ```csharp protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e) { if (e.Row.RowType == DataControlRowType.DataRow) { int totalBalanceQty = Convert.ToInt32(DataBinder.Eval(e.Row.DataItem, "TotalBalanceQty")); int maximumInventory = Convert.ToInt32(DataBinder.Eval(e.Row.DataItem, "MaximumInventory")); if (totalBalanceQty > maximumInventory) { e.Row.CssClass = "highlight-row"; } } } ``` 2. 在后端代码中设置行的样式: 在GridView的RowDataBound事件中,为符合条件的行设置背景颜色,例如: ```csharp protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e) { if (e.Row.RowType == DataControlRowType.DataRow) { int totalBalanceQty = Convert.ToInt32(DataBinder.Eval(e.Row.DataItem, "TotalBalanceQty")); int maximumInventory = Convert.ToInt32(DataBinder.Eval(e.Row.DataItem, "MaximumInventory")); if (totalBalanceQty > maximumInventory) { e.Row.BackColor = Color.Red; } } } ``` 请注意,无论您选择使用CSS样式还是在代码-behind中设置样式,都需要在GridView中的RowDataBound事件中调用相应的方法。同时,确保您已将该事件与GridView绑定,例如: ```asp.net <asp:GridView ID="GridView1" AutoGenerateColumns="false" runat="server" OnRowDataBound="GridView1_RowDataBound"> ``` 这样,当某一行的可用库存大于最大库存时,该行就会显示为红色背景。记得根据您的需求进行适当的调整和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值