❶ Eval方法和Bind方法的区别
Eval 方法是静态单向(只读)方法,所以Eval 函数用于单向(只读)绑定,该方法采用数据字段的值作为参数并将其作为字符串返回。
Bind 方法支持读/写功能,所以Bind 函数用于双向(可更新)绑定。该方法可以检索数据绑定控件的值并将任何更改提交回数据库。
❷ 大家知道asp.net那个读取数据库表字段的函数eval是什么意思
Eval方法实际上是TemplateControl的,而System.Web.UI.Page和System.Web.UI.UserControl都继承于TemplateControl,所以我们可以在Page和UserControl上直接调用个方法。
Page.Eval方法可以帮助我们更好的撰写数据绑定表达式,在ASP.NET 1.x时代,数据绑定表达式的一般形式是:
%# DataBinder.Eval( Container , “DataItem.Name”) %
而在ASP.NET 2.0中,同样的代码,我们可以这样写:
%# Eval( “Name” )%
ASP.NET 2.0是怎么实现的呢?我们先从Eval方法来研究,通过反射.NET Framework 2.0类库的源代码,我们可以看到这个方法是这样实现的:
protected internal object Eval(string expression)
{
this.CheckPageExists();
return DataBinder.Eval(this.Page.GetDataItem(), expression);
}
第一行我们不必管,这是检查调用的时候有没有Page对象的,如果没有则会抛出一个异常。
关键是第二行:
return DataBinder.Eval(this.Page.GetDataItem(), expression);
Page.GetDataItem()也是2.0中新增的一个方法,用途是正是取代ASP.NET 1.x中的Container.DataItem。
看来不摸清楚GetDataItem()方法,我们也很难明白Eval的原理。GetDataItem的实现也很简单:
public object GetDataItem()
{
if ((this._dataBindingContext == null) (this._dataBindingContext.Count == 0))
{
throw new InvalidOperationException(SR.GetString(“"Page_MissingDataBindingContext“"));
}
return this._dataBindingContext.Peek();
}
我们注意到了有一个内部对象_dataBindingContext,通过查源代码发现这是一个Stack类型的东西。所以他有Peek方法。而这一段代码很容易看懂,先判断这个Stack是否被实例化,然后,判断这个Stack里面是不是有任何元素,如果Stack没有被实例化或者没有元素则抛出一个异常。最后是将这个堆栈顶部的元素返回。
ASP.NET 2.0用了一个Stack来保存所谓的DataItem,我们很快就查到了为这个堆栈压元素和弹出元素的方法:Control.DataBind方法:
protected virtual void DataBind(bool raiseOnDataBinding)
{
bool flag1 = false;//这个标志的用处在上下文中很容易推出来,如果有DataItem压栈,则在后面出栈。
if (this.IsBindingContainer)//判断控件是不是数据绑定容器,实际上就是判断控件类是不是实现了INamingContainer
{
bool flag2;
object obj1 = DataBinder.GetDataItem(this, out flag2);//这个方法是判断控件是不是有DataItem属性,并把它取出来。
if (flag2 && (this.Page != null))//如果控件有DataItem
{
this.Page.PushDataBindingContext(obj1);//把DataItem压栈,PushDataBindingContext就是调用_dataBindingContext的Push方法
flag1 = true;
}
}
try
{
if (raiseOnDataBinding)//这里是判断是不是触发DataBinding事件的。
{
this.OnDataBinding(EventArgs.Empty);
}
this.DataBindChildren();//对子控件进行数据绑定,如果这个控件有DataItem,则上面会将DataItem压入栈顶,这样,在子控件里面调用Eval或者GetDataItem方法,就会把刚刚压进去的DataItem给取出来。
}
finally
{
if (flag1)//如果刚才有压栈,则现在弹出来。
{
this.Page.PopDataBindingContext();//PopDataBindingContext就是调用_dataBindingContext的Pop方法
}
}
}
❸ asp.net中 Eval()和Bind()是什么意思
绑定表达式
<%# Eval("字段名") %>
<%# Bind("字段名") %>
区别 1。eval是只读数据,Bind是可更新的.
2.当再次表达式操作时候,必须用Eval 如<%# Eval("字段名").ToString().Trim()%>
3.若GridView中绑定列里面 设置 内容格式 DataFormateString ={0:d} ,则 必须把 属性 HtmlCode 设置为false,否则无法起作用;
Eval 单向绑定:数据是只读的
Bind双向绑定:数据可以更改,并返回服务器端,服务器可以处理更改后的数据,如存入数据库.
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:D}")%> //----2006年10月27日
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:F}")%>//----2006年10月27日 8:31:44
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:G}")%>//----2006-10-27 8:31:44
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:M}")%>//----10月27日
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:R}")%>//----Fri, 27 Oct 2006 08:31:44GMT
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:T}")%>//----8:31:44
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:U}")%>//----2006年10月27日 0:31:44
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:Y}")%>//----2006年10月
对于程序员来说最根本的区别是:
1.Bind是可更新的,是Bind绑定列可编辑,并且可以和数据源控件交互,直接和数据库交互,但是用Bind的话,程序端的自定义操作就不能用了,比如Convert,ToString()等,或自己写的函数,在程序端都不可以
2.eval是只读数据,用eval的话不可以和数据源控件交互,是单向的,但是可以自定义操作
比如上面的<%# Eval("字段名").ToString().Trim()%>
本人从来和数据库交互自己写代码,所以对我来说操作的Eval更方便,基本不用Bind,而且以前写过,绑定泛型的时候
Bind都不支持嵌套类
以前从网上搜到的,不知道能不能帮到你
❹ sqleval是什么
你说的是不是数据库的?sqleval是个sqlserver安装的压缩包.
先安装sqleval,在安装的sqleval下找到autorun.exe,点击执行,才能真正的安装sqlserver。安装sqleval其实就是解压缩安装包,解压万后才能真正安装!
❺ 请问大家ASP.NET的aspx页面数据绑定<%# Eval(" 这里面是数据库的字段还是实体层的字段属性")%> 谢谢
1、<%# Eval(" 这里面是数据库的字段")%>
2、<%= 实体层的字段属性 %>
3、<% 这样相当是后台 %>,如:
<% if (!string.IsNullOrEmpty(base.StrCompanyName))
{ %>
<span style="font-size: 10pt; font-weight: bold;">
<br />
<%= base.StrCompanyName%>
</span>
<% } %>
❻ 关于ASP.NET中 Eval用法
先取得数据然后再substring 也就是<%# Eval("photoname").Substring(0,5)%>
或者直接在sql语句那控制 比如
select substring(ColumnA,0,5) from TableA ---------这是sqlserver的。。。