zoukankan      html  css  js  c++  java
  • C# eval()函数浅谈

    <%# Bind("Subject") %> //绑定字段

    <%# Container.DataItemIndex + 1%> //实现自动编号
    <%# DataBinder.Eval(Container.DataItem, "[n]") %>
    通常使用的方法(这三个性能最好)
    <%# DataBinder.Eval(Container.DataItem, "ColumnName") %>
    <%# DataBinder.Eval(Container.DataItem, "ColumnName", null) %>
    <%# DataBinder.Eval(Container, "DataItem.ColumnName", null) %>
    其他用法
    <%# ((DataRowView)Container.DataItem)["ColumnName"] %>
    <%# ((DataRowView)Container.DataItem).Row["ColumnName"] %>
    <%# ((DataRowView)Container.DataItem)["adtitle"] %>
    <%# ((DataRowView)Container.DataItem)[n] %>
    <%# ((DbDataRecord)Container.DataItem)[0] %>
    <%# (((自定义类型)Container.DataItem)).属性.ToString() %>//如果属性为字符串类型就不用ToString()了
    DataBinder.Eval用法范例
    <%# DataBinder.Eval(Container.DataItem, "IntegerValue", "{0:c}") %>
    格式化字符串参数是可选的。如果忽略参数,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:c} 货币样式
    <%#Container.DataItem("price","{0:¥#,##0.00}")%>
    <%# DataBinder.Eval(Container.DataItem,"Company_Ureg_Date","{0:yyyy-M-d}")%>
    Specifier Type      Format    Output (Passed Double 1.42)   Output (Passed Int -12400) 
    c   Currency         {0:c}      $1.42      -$12,400 
    d   Decimal          {0:d}     System.FormatException   -12400 
    e   Scientific       {0:e}     1.420000e+000     -1.240000e+004 
    f   Fixed point      {0:f}   1.42     -12400.00 
    g   General          {0:g}   1.42      -12400 
    n   Number with commas for thousands   {0:n}   1.42      -12,400 
    r   Round trippable     {0:r}   1.42      System.FormatException 
    x   Hexadecimal     {0:x4}   System.FormatException    cf90 

    {0:d} 日期只显示年月日
    {0:yyyy-mm-dd} 按格式显示年月日

    样式取决于 Web.config 中的设置
    {0:c}   或 {0:£0,000.00} 货币样式   标准英国货币样式
    <system.web>
    <globalization requestEncoding="utf-8" responseEncoding="utf-8" culture="en-US" uiCulture="en-US" />
    </system.web>
    显示为 £3,000.10

    {0:c}   或 string.Format("{0:C}", price); 中国货币样式
    <system.web>
    <globalization requestEncoding="utf-8" responseEncoding="utf-8" culture="zh-cn" uiCulture="zh-cn" />
    </system.web>
    显示为 ¥3,000.10

    {0:c}   或 string.Format("{0:C}", price); 美国货币样式
    <system.web>
    <globalization requestEncoding="utf-8" responseEncoding="utf-8" />
    </system.web>
    显示为 $3,000.10

    1,

    <asp:HyperLink runat="server" ID="hlUserName" Text='<%#DataBinder.Eval(Container.DataItem,"UserName") %>' NavigateUrl='<%# string.Format("UserView.aspx?uId={0}",Eval("UserId")) %>' />

    2,可以调用cs 中的内部函数和自定义函数:

    (1):

      <HyerLink runat="server" ID="hlUserName" Text='<%# DateTime.Now.ToString()%>' />

    (2):

     cs 中:

      protected string test(string s)

    {return s.ToUpper();}

    aspx中:

    <HyperLink runat="server" ID="hlUserName" Text='<%# test("aaa")%>'  />

    3,不放在控件中,直接调用函数

    <%= DateTime.Now.ToLongDateString()%>

    格式化日期: 

    <%# Eval("finishtime","{0:yyyy-MM-dd}") %>
       在绑定数据时经常会用到这个句程序:<%# DataBinder.Eval(Container.DataItem,"xxxx")%>或者<%# DataBinder.Eval(Container,"DataItem.xxxx")%>        微软这种方法的效率更高,但我不常用,我习惯了上一种。

    <%# ((DataRowView)Container.DataItem)["xxxx"]%> 用这种方法首先要在前台页面导入名称空间System.Data,否则会生成错误信息。

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

          DataBinder.Eval()可以梆定方法,Text='<%# PBnumber(DataBinder.Eval(Container.DataItem,"photoBookID")) %>后台代码:
            protected string PBnumber(object PBid)
            {

                string str = "[ " + Convert.ToString(PBc.GetInPbkPnum((int)PBid)) + " ] 张";

                return str;
            }

           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(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:c} 货币样式

     本文假设你已经了解ASP.NET 1.1的数据绑定(特别是Container这个局部变量)的机制,这里主要分析ASP 2.0数据绑定做了那些改进。 

      ASP.NET 2.0 的数据绑定函数Eval()简化掉了ASP 1.1神秘的Container.DataItem,比如数据绑定表达式:

    <%# (Container.DataItem as DataRowView)["ProductName"].ToString() %>

      ASP.NET 1.1简化为:(去掉了类型指定, Eval通过反射实现,本文不再阐述)

    <%# DataBinder.Eval(Container.DataItem, "ProductName").ToString() %>

      ASP.NET 2.0又简化为,去掉了Container局部变量:

    <%# Eval("ProductName") %>

      那么,Page.Eval()又是如何知道"ProductName"是那个数据的属性呢,即Container.DataItem真的消失了吗?

      Eval()是Page的父类TemplateControl的方法

      TemplateControl.Eval()可以自动计算出Container, 机制就是从一个dataBindingContext:Stack堆栈来获取。

      1. 建立DataItem Container 栈:

      在Control.DataBind()中,建立,这样可以保证子控件的DataItem Container始终在栈顶。

    public class Control
    {
     protected virtual void DataBind(bool raiseOnDataBinding)
     {
      bool foundDataItem = false;
      if (this.IsBindingContainer)
      {
       object o = DataBinder.GetDataItem(this, out foundDataItem);
       if (foundDataItem)
        Page.PushDataItemContext(o); <-- 将DataItem压入堆栈
      }
      try
      {
       if (raiseOnDataBinding)
        OnDataBinding(EventArgs.Empty);

       DataBindChildren(); <-- 绑定子控件
      }
      finally
      {
       if (foundDataItem)
        Page.PopDataItemContext(); <-- 将DataItem弹出堆栈
      }
     }
    }

      2. 获取DataItem Container

    public class Page

     public object GetDataItem()
     {
      ...
      return this._dataBindingContext.Peek(); <-- 读取堆栈顶部的DataItem Container,就是正在绑定的DataItem    Container
     }
    }

      3. TemplateControl.Eval()

    public class TemplateControl
    {
     protected string Eval (string expression, string format)
     {
      return DataBinder.Eval (Page.GetDataItem(), expression, format); 
     }
    }

      
    结论:

      从上面看出Page.Eval()在计算的时候还是引用了Container.DataItem,只不过这个DataItem通过DataItem Container堆栈自动计算出来的。我认为Page.Eval()看似把问题简化了,其实把问题搞得更加神秘。
  • 相关阅读:
    Mybatis插入数据时 返回主键
    React 子组件state内数组修改页面不刷新问题
    React 配合echarts使用问题记录
    vue 项目启动报错
    React Ant design table表单与pagination分页配置
    React Cascader组件实现地址选择
    os常用指令
    React 页面间传参
    React Router配置
    react项目 npm run eject报错
  • 原文地址:https://www.cnblogs.com/Impulse/p/5054056.html
Copyright © 2011-2022 走看看