zoukankan      html  css  js  c++  java
  • ASP.NET开发,且编且改,分清职责

    本篇Insus.NET使用一个实例,分享在ASP.NET开发时,一个功能一个方法(函数),且编且改,一步一个脚印把实例完成。在方法多变多形式的情况之下,怎样把写出来程序简单明了。

     
    下面是一个Excel文档:
    http://download.cnblogs.com/insus/ASPDOTNET/Book1.rar

    现在是要读取它,并显示于GridView控件上,方法参考《Excel上传并读取数据http://www.cnblogs.com/insus/p/3814857.html 由于一些字段在本篇中,无用,因此删除之。

    "SELECT [性别],[所属部门],[职务],[在职否] FROM [Sheet1$]"

     
    我们在xxx.aspx 的html markup中。拉一个GridView控件,并使用自定义模版:

    读取Excel演示:

     现在要求来了,用户需要读取与加载Excel至GridView之后,希望能编辑数据。但不想按照传统方式一样,一行一行点击编辑铵钮之后,才能进入编辑状态,而一开始就是能编辑。怎样实现编辑,四个字段,前后字段“性别”与“在职否”,只有两个值。“男”与“女”; “在职”与“离职” 可以使用RadioButtonList控件。而中间两个字段中“所属部门”与“职位”,多值呈现,可以使用DropDownList控件:

     既然有控件,我们需要拿数据源来给这些控件数据绑定。由于这些控件均是在GridView控件内的,绑定在OnRowDataBound事件中进行。

    四个嵌套在GridView控件内的控件数据绑定:


    上面代码示例中,Insus.NET只做两个控件的示意,一个DropDownList和一个RadioButtonList。它们的数据源有来自数据库,有来自函数。你需要指定显示的数据(DataTextFeid),哪一个用作后端获取的数据(DataValueField)。这需要根据你开发时的需求了。


    写到这里,你发现四个控件在绑定数据源时,有代码冗余:

     ccc.DataSource = xxx;
     ccc.DataTextField = yyy;
     ccc.DataValueField = zzz;
     ccc.DataBind();


    我们可以重构为一个方法,在重构之前,我们会遇上二个问题要考虑的,一个是控件不同。RadioButtonList和DropDownList;二是被绑定的数据源不同,一些为泛型,DataTable等。处理好这些,需要想出一个万全之策。如:

    看到两个红箭头否,由于RadioButtonList和DropDownList控件,均是继承了ListControl控件。数据源不管是什么,均宣告为object即可。然后上面的四个控件的绑定,就可以使用这个方法了:


    如果把注释掉的代码拿掉,是不是简洁多了?看看运行时浏览的效果:

     


    现在看到一个问题,中间两个DropDownList下拉列表,没有“--选择--”选项。怎样加入第一个项呢?哦,这个简单:


    添加上面两行高亮代码,得到地效果如下:

     

    到现在为止,我们只是对控件进行数据源绑定。回头来看看下载的Excel数据:

     正确来说,应该是把数据原始状态一起绑定,OK,解决此问题,再写程序:

    把每笔记录与控件绑定的数据时行匹配,匹配的,改变状态。
    浏览看看结果:


    嗯,越来越接近理想的要求了。开发就是这样,一个功能,一个方法或是一个函数,分清职责。
    呵呵明眼人,又会看到上面的代码有冗余了:

     foreach (ListItem li in ccc.Items)
                        li.Selected = li.Text == drv["xxx"].ToString() ? true : false;


    Insus.NET在开发过程中,一旦发现有代码冗余,必需重构之,不然看上去就不舒服。创建一个方法吧:

    有关这个方法,你还可以参考另外一篇《没有什么,开发ASP.NET时随便写写,想到什么写什么http://www.cnblogs.com/insus/p/3810032.html 将学到更好的方法重构。

    写好这个公用的方法之后,我们去改写那些冗余的代码:

     一步一个步骤,把程序写好......

  • 相关阅读:
    MYSQL查询练习 1
    Mysql语句练习记录
    博客园背景样式修改
    MYSQL安装与卸载(一)
    IDEA 使用与总结
    解决layui弹窗提示刷新页面一闪而逝的问题
    System.Xml.XmlException: 分析 EntityName 时出错
    PS快速把倾斜的图片调正
    iis添加asp.net网站,访问提示:由于扩展配置问题而无法提供您请求的页面。如果该页面是脚本,请添加处理程序。如果应下载文件,请添加 MIME 映射
    c# 递归查找父类的子类
  • 原文地址:https://www.cnblogs.com/insus/p/3817682.html
Copyright © 2011-2022 走看看