论不使用ObjectDataSource之数据绑定控件纯代码实现是否更优化?

简介:


看了园子里面的两篇关于数据绑定的文章(使用objectdatasource结合数据绑定控件进行简单三层架构的开发 和 使用objectdatasource结合数据绑定控件进行简单三层架构的开发 [绝版]),终于让我按捺不住想写点我的看法。

对于数据绑定的相关使用,我跟许多人一样,也有着许多的感受。
一开始先是使用VS 2003中的DataGrid+SqlConnection、SqlCommand、SqlDataAdapter,到后来使用VS 2005中的GridView+ObjectDataSource。当那些SqlConnection、SqlCommand、SqlDataAdapter都被ObjectDataSource一次性搞定,其简洁的数据绑定代码让我兴奋不已,的确帮我省去了不少的工夫。然而好景不长,在项目的实际需求开发中,逐渐发觉它的存在反而降低了代码的灵活性和重用性,程序似乎是变得“傻瓜化”了,同时把我也弄得有些“傻瓜化”了,^_^ 以至于后来忍痛割爱,但凡数据绑定控件的相关问题干脆用代码实现。

现在还来谈论GridView以及ObjectDataSource的使用,的确有点老生常谈的感觉,但我希望通过这个切入点来讨论一下我对服务器控件的使用心得,以及相关的一些看法:

一、 我个人觉得,对于服务器控件,能不用的地方就尽量不要使用。比如说,能用html的table来展现的数据,就不必要使用Repeater,而能用Repeater很好展现数据的时候就不必要使用DataList,逼不得已才使用GridView以及DetailsView等等。牛刀也能杀鸡,但更合理的做法应该是让牛刀在杀牛的时候才使用。所以,我在使用控件的时候,考虑更多的是让代码尽量简洁高效,但绝不是偷工减料。

二、 我个人觉得,即使在使用服务器控件的时候,相关的代码应该尽量在后台完成。这样做的原因,一是提高了代码的灵活性;二是提高了代码的可重用性。毕竟aspx前台页面承载的东西太多,HTML、CSS、JavaScript已经让它变得很臃肿,加之在VS 2005中,aspx前台页面是不能调试的(VS 2008中应该可以了),要是再把一些服务器控件的代码过多的堆砌上去,可想而知,它的可读性和维护性是多么让人晦涩的。

三、 我个人觉得,对于数据库访问方面的一些技术和控件,应该尽量使用权威性和大众化的。权威性的东西(我这里意指得到大多数人认同的东西)在一定程度上就表示了它的健壮性、安全性以及可行性。观众的眼睛是雪亮的,所以我更相信群众。而大众化的东西在团队编程和版本更新等等方面更容易融合。所以,在简单的项目开发中,数据库访问方面我认为一般使用SqlHelper或者企业库就能够应付;而对于复杂庞大的系统,能够用上LINQ或者NHibernate也应该足够。毕竟我们是在帮客户开发产品,客户喜欢的应该是最美的结果,而不是最复杂的技术。

四、 我个人觉得,从事编程不久(或者说内力不深)的程序员,更应该有一个务实的心态。比如我,刚来园子的时候,特别好奇于各种新鲜的技术,首页的文章惟恐一篇被我漏过。结果囫囵吞枣,似懂非懂,导致自己对技术的掌握反倒华而不实。就拿当时刚刚兴起的AJAX来说,在DotNET中其实三个控件就可以搞定。所以,一般情况下只需要掌握了它的相关原理并能灵活的使用,就足已应对大部分的情况了。如果在一个对局部刷新要求并不高的系统中,硬是给它安个AJAX框架之类的东东,那恐怕不只是画蛇添足的问题了。我这样说只是强调,我们应该花更多的时间来看一些全面深入的书籍以及系统的帮助上,以提高自己的内力。只有内功深厚了,才能以不变应万遍的面对各种接踵而来的技术革新和项目难题。

当然,这些观点都只是我的片面之词,不具有权威性和可靠的正确性,错漏之处还请给予斧正。

为了免除我在这里纸上谈兵的尴尬,特地编写了一个Demo以体现我上述的相关观点和编程习惯。下面的这种设计方式应该足够应付小型系统的开发。
它的特点是:没有使用ObjectDataSource控件,数据绑定控件的设置全部是以代码实现,还有就是三层结构的思想+改进的SqlHelper数据库操作。而优点就是我上面所提及的。

先来看看相关截图:


页面运行前的GridView控件


页面运行后的GridView控件展现


页面运行后GridView控件的编辑状态

实现步骤:
一、在aspx页面上,只放入一个GridView控件并指定其ID。
Default.aspx

<% @ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default"  %>

<! 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 >GridView_Demo </ title >
</ head >
< body >
     < form  id ="form1"  runat ="server" >
     < div >
         < asp:GridView  ID ="myGrid"  runat ="server"   >
         </ asp:GridView >
     </ div >
     </ form >
</ body >
</ html >

二、在aspx.cs类文件中,把GridView控件的各种外观设置,数据绑定等等都用代码的形式控制,这样做的好处是对GridView能够灵活的控制,代码的重用性极高。弱点应该是代码量比较大(或许还有我看不见的)。
Default.aspx.cs

using System;
using System.Data;
using System.Configuration;
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;
// myself
using System.Drawing;

public  partial  class _Default : System.Web.UI.Page 
{
    private Employees.Employees_BLL bll = new Employees.Employees_BLL();

    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            //设置GridView外观样式
            setGridViewStyle();

            //创建及设置Fields字段
            setFields();

            //设置 GridView 数据源绑定
            GridBind();
        }

        //以后台的方式添加 GridView 的各类事件
        myGrid.RowEditing += new GridViewEditEventHandler(myGrid_RowEditing);
        myGrid.RowUpdating += new GridViewUpdateEventHandler(myGrid_RowUpdating);
        myGrid.RowCancelingEdit += new GridViewCancelEditEventHandler(myGrid_RowCancelingEdit);
        myGrid.RowDeleting += new GridViewDeleteEventHandler(myGrid_RowDeleting);
    }


    方法  方法

    // GridView 编辑操作
    protected void myGrid_RowEditing(object sender, GridViewEditEventArgs e)
    {
        //设置编辑行的索引
        myGrid.EditIndex = e.NewEditIndex;

        //设置更新与取消按钮之背景颜色
        myGrid.Columns[0].ControlStyle.BackColor = Color.LightSteelBlue;
        myGrid.Columns[1].ControlStyle.BackColor = Color.LightSteelBlue;
        myGrid.ShowFooter = true;
        //设置GridView在编辑模式时,TextBox字段宽度及背景颜色
        
//EmployeeID字段
        myGrid.Columns[2].ControlStyle.Width = 80;
        myGrid.Columns[2].ControlStyle.BackColor = Color.LightBlue;
        myGrid.Columns[2].FooterText = "不可编辑";
        myGrid.Columns[2].FooterStyle.BackColor = Color.Red;
        //LastName字段
        myGrid.Columns[3].ControlStyle.Width = 80;
        myGrid.Columns[3].ControlStyle.BackColor = Color.LightBlue;
        myGrid.Columns[3].FooterText = "不可编辑";
        myGrid.Columns[3].FooterStyle.BackColor = Color.Red;
        //FirstName字段
        myGrid.Columns[4].ControlStyle.Width = 80;
        myGrid.Columns[4].ControlStyle.BackColor = Color.LightBlue;
        myGrid.Columns[4].FooterText = "可编辑";
        myGrid.Columns[4].FooterStyle.BackColor = Color.Red;
        //Title字段
        myGrid.Columns[5].ControlStyle.Width = 100;
        myGrid.Columns[5].ControlStyle.BackColor = Color.LightPink;
        myGrid.Columns[5].FooterText = "可编辑";
        myGrid.Columns[5].FooterStyle.BackColor = Color.Red;
        //Address字段
        myGrid.Columns[6].ControlStyle.Width = 120;
        myGrid.Columns[6].ControlStyle.BackColor = Color.LightPink;
        myGrid.Columns[6].FooterText = "可编辑";
        myGrid.Columns[6].FooterStyle.BackColor = Color.Red;
        //City字段
        myGrid.Columns[7].ControlStyle.Width = 80;
        myGrid.Columns[7].ControlStyle.BackColor = Color.LightGreen;
        myGrid.Columns[7].FooterText = "可编辑";
        myGrid.Columns[7].FooterStyle.BackColor = Color.Red;
        GridBind();
    }

    // GridView 更新操作
    protected void myGrid_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        if (e.NewValues != e.OldValues)
        {
            Employees.Employees_Model model = new Employees.Employees_Model(); 
            model.EmployeeID = Convert.ToInt32(myGrid.Rows[e.RowIndex].Cells[2].Text.Trim());
            //Employees_DAL 中的 where 条件为 EmployeeID and LastName, 所以 LastName 不能更改
            model.LastName = myGrid.Rows[e.RowIndex].Cells[3].Text.ToString();
            model.FirstName = ((TextBox)myGrid.Rows[e.RowIndex].Cells[4].Controls[0]).Text.ToString();
            model.Title = ((TextBox)myGrid.Rows[e.RowIndex].Cells[5].Controls[0]).Text.ToString();
            model.Address = ((TextBox)myGrid.Rows[e.RowIndex].Cells[6].Controls[0]).Text.ToString();
            model.City = ((TextBox)myGrid.Rows[e.RowIndex].Cells[7].Controls[0]).Text.ToString();
            //Employees.BLL.Employees_Model bll = new Employees.BLL.Employees_Model();
            bll.Update(model);

            //取消编辑时隐藏Footer
            myGrid.ShowFooter = false;
            //设置"编辑"和"删除"按钮还原为系统定义的颜色
            myGrid.Columns[0].ControlStyle.BackColor = Color.LightPink;
            myGrid.Columns[1].ControlStyle.BackColor = Color.LightPink;
            myGrid.EditIndex = -1;
            GridBind();
        }

    }

    // GridView 取消事件
    protected void myGrid_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {
        //取消编辑时隐藏Footer
        myGrid.ShowFooter = false;
        //设置"编辑"和"删除"按钮还原为系统定义的颜色
        myGrid.Columns[0].ControlStyle.BackColor = Color.LightPink;
        myGrid.Columns[1].ControlStyle.BackColor = Color.LightPink;
        myGrid.EditIndex = -1//取消编辑状态
        GridBind();
    }

    // GridView 删除操作
    protected void myGrid_RowDeleting(object sender, GridViewDeleteEventArgs e)
    {
        //设置更新与取消按钮之背景颜色
        myGrid.Columns[0].ControlStyle.BackColor = Color.LightSteelBlue;
        myGrid.Columns[1].ControlStyle.BackColor = Color.LightSteelBlue;
        // 获取 Employees_DAL 中的 where 条件: EmployeeID and LastName
        int strEmployeeID = Convert.ToInt32(myGrid.DataKeys[e.RowIndex].Values[0]);
        string strLastName = myGrid.Rows[e.RowIndex].Cells[3].Text.ToString();
        bll.Delete(strEmployeeID, strLastName);  //删除
        GridBind();
    }
 
}

三、这是业务逻辑层,如果代码量不大,可以整合到aspx.cs类文件中。
Employees_BLL.cs

using System;
using System.Data;

namespace Employees
{
    /// <summary>
    
/// 业务逻辑类Employees_BLL 的摘要说明。
    
/// </summary>

    public class Employees_BLL
    {
        private readonly Employees.Employees_DAL dal=new Employees.Employees_DAL();
        public Employees_BLL()
        {}
        成员方法  成员方法
    }

}

四、数据访问层,这个没有什么好说的。
Employees_DAL.cs

using System;
using System.Data;
using System.Text;
using System.Data.SqlClient;

namespace Employees
{
    /// <summary>
    
/// 数据访问类Employees_DAL
    
/// </summary>

    public class Employees_DAL
    {
        public Employees_DAL()
        {}
        成员方法  成员方法
    }

}

五、数据实体类,关于这个我不得不提及请指点--关于数据访问层(2)这篇文章中作者的第一个问题,我个人觉得实体类的属性尽量保持跟数据库表的字段保持一致,如果项目实际需要,也可以在其中既包括外键ID也包含外键ID对应的名称。
Employees_Model.cs

using System;

namespace Employees
{
    /// <summary>
    
/// 实体类Employees_Model
    
/// </summary>

    public class Employees_Model
    {
        public Employees_Model()
        {}
        Model Model
    }

}

六、扩充了相关功能的SqlHelper
DbHelperSQL.cs

Demo下载:Employees_Demo.rar
说明:由于SQL 2000中,默认Northwind数据库的Employees表的EmployeeID字段存在约束和主外键关系,所以删除记录时会报错。在这里,我简单的创建了一个myNorthwind数据库,并添加了一个Employees表(在App_Data文件夹中)。




本文转自钢钢博客园博客,原文链接:http://www.cnblogs.com/xugang/archive/2008/04/23/1168398.html,如需转载请自行联系原作者

相关文章
|
5月前
|
容器 C# 开发者
XAML语言大揭秘:WPF标记的魅力所在,让你轻松实现界面与逻辑分离,告别复杂代码!
【8月更文挑战第31天】XAML提供了一种直观且易于维护的界面设计方式,使得开发者可以专注于逻辑和业务代码的编写,而无需关心界面细节。通过数据绑定、布局管理和动画效果等特性,XAML可以实现丰富的界面交互和视觉效果。在实际开发过程中,开发者应根据具体需求选择合适的技术方案,以确保应用程序能够满足用户的需求。希望本文的内容能够帮助您在WPF应用程序开发中更好地利用XAML语言。
55 0
|
5月前
|
开发者 C# Windows
WPF布局大揭秘:掌握布局技巧,轻松创建响应式用户界面,让你的应用程序更上一层楼!
【8月更文挑战第31天】在现代软件开发中,响应式用户界面至关重要。WPF(Windows Presentation Foundation)作为.NET框架的一部分,提供了丰富的布局控件和机制,便于创建可自动调整的UI。本文介绍WPF布局的基础概念与实现方法,包括`StackPanel`、`DockPanel`、`Grid`等控件的使用,并通过示例代码展示如何构建响应式布局。了解这些技巧有助于开发者优化用户体验,适应不同设备和屏幕尺寸。
168 0
|
8月前
|
编解码 前端开发 开发者
构建响应式网页布局的终极指南
【2月更文挑战第18天】 随着移动互联网的兴起,响应式网页设计成为前端开发者必须掌握的核心技能之一。本文旨在提供一个全面的指南来帮助开发者理解并实现灵活且高效的响应式布局。我们将深入探讨媒体查询、弹性盒模型、相对单位等关键技术,并通过实例演示如何结合这些技术创建适应不同屏幕尺寸的网页。文章的目标是让读者能够独立设计和开发出在各种设备上均能提供优秀用户体验的响应式网站。
151 1
|
8月前
|
前端开发 开发者 UED
构建响应式网页布局的现代方法
【2月更文挑战第13天】随着移动互联网的兴起,为不同设备设计适配的网页变得至关重要。本文深入探讨了使用Flexbox和Grid两种CSS布局技术构建响应式网页的方法,分析了它们的优劣,并通过实例展示了如何有效地运用这些技术以提升页面的响应性和用户体验。
|
前端开发 UED
响应式Web设计的原理与实践
响应式Web设计的原理与实践
120 0
|
C#
[WPF 容易忽视的细节] —— x:Name与Name属性
原文:[WPF 容易忽视的细节] —— x:Name与Name属性 一、前言 WPF使用XAML来对界面进行编写,界面与后台逻辑分离。我们也可以写Style、Trigger来实现一些界面效果, 这些都是通过Name来定位控件的,例如Setter.TargetName、Trigger.SourceName和Binding的ElementName等。
1140 0
|
C#
在WPF中减少逻辑与UI元素的耦合
原文:在WPF中减少逻辑与UI元素的耦合              在WPF中减少逻辑与UI元素的耦合 周银辉 1,    避免在逻辑中引用界面元素,别把后台数据强加给UI  一个糟糕的案例 比如说主界面上有一个显示当前任务状态的标签label_TaskState,我们会时常更新该标签以便及时地将任务状态通知用户。
1053 0
Mockplus组件样式库一键解决风格复用
在Mockplus3.3版本中,新增了组件样式库,可以快速复用组件风格,同时可以将组件风格保存到库中。 官网地址:https://www.mockplus.cn 1.保存样式 选中组件,设置好该组件的外观后,点击图中的加号,即可把组件当前的外观属性保存起来。
1628 0