数据绑定表达式(上):.NET发现之旅(一)

简介:


作为.NET平台软件开发者,我们频繁与各种各样的数据交互,这些数据常常来源于文本、自定义类型、XML、数据库等,访问这些数据有很多方法,而数据绑定表达式便是其中最常用也是最实用的方法之一。我用2篇博文,尽量说透.NET平台数据绑定表达的来源,使用方法,底层原理,效率等。另外这2篇博文我最初发表于博客园。

 
一,概要
数据绑定表达式必须包含在<%#%>字符之间。格式如下:
<tagprefix:tagname property='<%# data-binding expression %>' runat="server" />
 
或者如下:
<%# data-binding expression %>
ASP.NET  支持分层数据绑定模型,数据绑定表达式使用 Eval  Bind 方法将数据绑定到控件,并将更改提交回数据库。
Eval 
方法是静态单向(只读)方法,所以Eval 函数用于单向(只读)绑定,该方法采用数据字段的值作为参数并将其作为字符串返回。
Bind 
方法支持读/写功能,所以Bind 函数用于双向(可更新)绑定。该方法可以检索数据绑定控件的值并将任何更改提交回数据库。
XPath 
方法支持对XML类型的数据源提供支持。

二,
数据绑定表达式出现的位置

1,可以将数据绑定表达式包含在服务器控件或者普通的html元素的开始标记中属性名/属性值对的值侧。例如:
<asp:TextBox ID="TextBox1" runat="server" Text='<%# 数据绑定表达式%>' ></asp:TextBox><br />
此时数据的绑顶表达式可以是一个变量,也可以是一个带返回值的C#或者VB.NET方法,还可以是某个控件的某个属性的值,也可以是C#或者VB.NET对象的某个字段或者属性的值等等。当然也可以直接就是一个字符串,例如"hello"
如果此时的数据绑定表达式是Eval("数据库中某个表的某个字段"),那么必须把TextBox1放在某个循环显示的控件的模板中才正确,否则会提示:Eval()XPath()  Bind() 这类数据绑定方法只能在数据绑定控件的上下文中使用。其实就是想让你把TextBox1放在像Repeater,DataList,GridView这样的控件的模板中。

2,数据绑定绑定表达式包含在在页面中的任何位置。例如:
<form id="form1" runat="server">
    
<div>
   
  <%#Eval("数据绑定表达式1")%>   
   
  <%#Eval("数据绑定表达式2")%>
        
    
</div>  
</form>
此时数据的绑顶表达式可以是一个变量,也可以是一个带返回值的C#或者VB.NET方法,还可以是某个控件的某个属性的值,也可以是C#或者VB.NET对象的某个字段或者属性的值等等。当然也可以直接就是一个字符串,例如"hello"
如果此时的数据绑定表达式是Eval("数据库中某个表的某个字段"),那么必须把<%#Eval("数据绑定表达式1")%>  <%#Eval("数据绑定表达式2")%>  放在像Repeater,DataList,GridView这样的控件的模板中。

3
,可以将数据绑定表达式包含在Javascript代码中,从而实现在Javascript中调用C#或者VB.NET的方法。例如:
Deafult2.aspx:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    
<title>无标题页</title>
    
<script language ="javascript" type="text/javascript">
    
function  GetStr()
    {
       
var
 a; 
       a = ''; 
       a='<%#CSharpToJavascript()%>'         
//
调用c#的方法
       alert(a);
    }
    
</script>
    
</head>
<body>
    
<form id="form1" runat="server">
    
<div>
        
<input id="Button1" type="button" value="Javascript调用c#的方法!" onclick="GetStr()" /</div>  
    
</form>
</body>
</html>
Default2.cs:
using  System;
using
 System.Data;
using
 System.Configuration;
using
 System.Collections;
using
 System.Web;
using
 System.Web.Security;
using
 System.Web.UI;
using
 System.Web.UI.WebControls;
using
 System.Web.UI.WebControls.WebParts;
using
 System.Web.UI.HtmlControls;

public partial class
 Default2 : System.Web.UI.Page
{
    
protected void Page_Load(object
 sender, EventArgs e)
    {
        Page.DataBind();
//
方法有返回值的要先绑定,才能实现Javascript调用c#的方法!
    }
    
public string
 CSharpToJavascript()
    {
        
return "Javascript调用c#的方法!"
;
    }
}
三,数据绑定表达可以是什么类型?
1 ,可以是一个变量
例如:<asp:Label ID="Label1" runat="server" Text="<%#变量名%>"></asp:Label>
2
,可以是服务器控件的属性值

例如: <asp:Label ID="Label1" runat="server" Text="<%#TextBox2.Text %>"></asp:Label>
3
,可以是一个数组等集合对象

例如把一个数组绑定到列表控件,例如ListBox等,或者Repeater,DataList,GridView这样的控件等,此时只需要把属性DataSource='<%# 数组名%>' 
4
,可以是一个表达式
例如:Person是一个对象,NameCity是它的2个属性,则数据绑定表达式可以这样写:
<%#(Person.Name + " " + Person.City)%>

5
,可以是一个方法
例如:<%#GetUserName()%>GetUserName()是一个已经定义的C#方法,一般要求有返回值。
6,
可以是用Eval,DateBinder.Eval取得的数据表的字段,这个是最常见的了,不再举例。

注意:如果数据绑定表达式作为属性的值,只要数据绑定表达式中没有出现双引号,那么<%#数据绑定表达式%>的最外层用双引号或者单引号都可以。如果数据绑定表达式中出现双引号,则<%#数据绑定表达式%>的最外层最好要用单引号。

四,与数据库有关而且绑定到DataView,DataTable,DataSet 等数据源的数据绑定表达式都有那些?

1
<%#DataBinder.Eval(Container.DataItem,"字段名")%>
      <%#DataBinder.Eval(Container.DataItem,"
字段名
","{0:c}") %>
     
还有2种不常用的:

      <%# DataBinder.Eval(Container,"DataItem.
字段名")%> 
      <%# DataBinder.Eval(Container,"DataItem.
字段名"
{0:c})%> 
      Container.DataItem
相当于数据库中某个表或者视图中的一行记录,而一行可以有很多列。
  使用三目运算符?:的例子:
 <%# DataBinder.Eval(Container.DataItem, "
字段名").ToString().Trim().Length>16DataBinder.Eval(Container.DataItem, "字段名").ToString().Trim().Substring(0,16):DataBinder.Eval(Container.DataItem, "字段名").ToString().Trim() %>

2
<%#Eval("字段名
")%>
     <%#Eval("
字段名
","{0:c}")%>
     .NET 2.0
新出现的一个方法。和DataBinder.Eval()等价。
 绑定生日的例子:
              <%#string.Format("{0:yyyy-MM-dd dddd}",Eval("stuBirth"))%>
            
<%# DataBinder.Eval(Container.DataItem,"stuBirth","{0:yyyy-MM-dd}")%>
使用三目运算符的例子:
<%#(Eval("性别")).ToString() =="True"?"":""%>  
 
性别字段类型为:是/(Access)bit(sql server)
   调用方法的例子:
  <%# GetUserPhoto(Eval("PhotoPath")) %>    
     GetUserPhoto()
的定义:
string GetUserPhoto(object  photoPath)
{
  
if (photoPath == DBNull.Value)<%#((DataRowView)Container.DataItem)["
字段名"] %>
绑定到
DataView,DataTable,DataSet
  {
      
return "<img src='Images/none.gif'>" ;
  }
  
else

  {
    
return "<img src='Upload/" +photoPath.ToString() + "'>" ;
  }
}
 
 3  <%#((DataRowView)Container.DataItem)["字段名"] %>
      <%# string.Format("{0:c}", ((DataRowView)Container.DataItem)["
字段名
"])%>
      Container.DataItem
相当于数据库中某个表或者视图中的一行记录,而一行可以有很多列。
   
类型转换后相乘的例子:
<%# (int)((DataRowView)Container.DataItem)["字段名1"]*(int)((DataRowView)Container.DataItem)["字段名2"]%>  
   
上面三种绑定方法的效率:Eval方法执行时候会调用DataBinder.Eval方法,DataBinder.Eval方法在运行时使用反射执行后期绑定计算,会导致性能明显下降。所以会导致性能明显下降。所以三者中<%#((DataRowView)Container.DataItem)["字段名"] %>的性能最好。
下一篇分析数据绑定表达的底层实现,来源,执行效率等。敬请期待。












本文转自terryli51CTO博客,原文链接: http://blog.51cto.com/terryli/150586,如需转载请自行联系原作者


相关文章
|
前端开发 JavaScript 数据可视化
最棒的 7 个 Laravel admin 后台管理系统推荐
Laravel 已经凭借自己的易用性及低门槛成为 github 上 stars 第一的 PHP 框架,本文将介绍我精心为大家挑选出来的 Laravel admin 后台管理系统,从抽象程度最低(灵活但代码量大)到抽象程度最高(代码量小但不灵活)来帮助大家选择合适自己的 Laravel admin 后台管理系统。
3230 0
|
7月前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
356 1
|
9月前
|
机器学习/深度学习 自然语言处理 算法
大数据与机器学习
大数据与机器学习紧密相关,前者指代海量、多样化且增长迅速的数据集,后者则是使计算机通过数据自动学习并优化的技术。大数据涵盖结构化、半结构化及非结构化的信息,其应用广泛,包括商业智能、金融和医疗保健等领域;而机器学习分为监督学习、无监督学习及强化学习,被应用于图像识别、自然语言处理和推荐系统等方面。二者相结合,能有效提升数据分析的准确性和效率,在智能交通、医疗及金融科技等多个领域创造巨大价值。
459 2
|
4月前
|
人工智能 搜索推荐 数据可视化
Manus:或将成为AI Agent领域的标杆
随着人工智能技术的飞速发展,AI Agent(智能体)作为人工智能领域的重要分支,正逐渐从概念走向现实,并在各行各业展现出巨大的应用潜力。在众多AI Agent产品中,Manus以其独特的技术优势和市场表现,有望成为该领域的标杆。作为资深AI工程师,本文将深入探讨Manus的背景知识、主要业务场景、底层原理、功能的优缺点,并尝试使用Java搭建一个属于自己的Manus助手,以期为AI Agent技术的发展和应用提供参考。
12288 19
|
存储 XML 编解码
PyMuPDF 1.24.4 中文文档(八)(3)
PyMuPDF 1.24.4 中文文档(八)
486 1
|
7月前
|
Linux 调度 C语言
深入理解操作系统:从进程管理到内存优化
本文旨在为读者提供一次深入浅出的操作系统之旅,从进程管理的基本概念出发,逐步探索到内存管理的高级技巧。我们将通过实际代码示例,揭示操作系统如何高效地调度和优化资源,确保系统稳定运行。无论你是初学者还是有一定基础的开发者,这篇文章都将为你打开一扇了解操作系统深层工作原理的大门。
104 4
|
存储 XML 数据安全/隐私保护
PyMuPDF 1.24.4 中文文档(八)(2)
PyMuPDF 1.24.4 中文文档(八)
950 1
|
API Python
Python中使用pyzbar实现二维码生成和识别功能
Python中使用pyzbar实现二维码生成和识别功能
1332 0
|
关系型数据库 MySQL 大数据
MySQL索引失效的原因及应对策略
引言 在大数据时代,数据库管理成为了每个开发者必备的技能之一。MySQL作为全球最受欢迎的开源关系数据库管理系统,深受开发者们的喜爱。为了提高查询效率,我们常常会在MySQL中使用索引,但有时候你会发现,索引并没有发挥出预期的作用,原来,它已经“失效”了。本文将带你探索MySQL中索引失效的原因以及如何避免,让我们一同跨入数据库的奇妙世界。
1420 0