专栏首页更流畅、简洁的软件开发方式能自己“跑”的表单控件,思路,雏形,源码。vs2005版本

能自己“跑”的表单控件,思路,雏形,源码。vs2005版本

下载地址:

 http://www.cnblogs.com/jyk/archive/2008/07/29/1255891.html

大家是怎么处理CRUD的呢?

这里说一下添加、修改数据。

    一大堆的表,n多的字段,经常变化的表现形式(比如文本框换成下拉列表框等),是不是很头痛?反正我是很烦的,因为我太懒了,对于这种不是太重要的,但是有很繁琐的东东,我总是要向出来一种“简单”的方式来处理。

    怎么办?表单控件,我还一直使用VS2003,没有VS2005里面的表单控件,所以只好自己写了,另外好像VS2005里面的表单控件使用的也不是很多。

    我的表单控件要做的事情:

    1、自己描绘控件,比如能够自己添加文本框、下拉列表框这一类的控件。

    2、可以自己获取用户输入的信息,进行验证(前台的js验证和后台的数据的类型是否符合子段类型的验证),组合SQL语句或者调用存储过程来添加、修改数据。

    3、在修改数据的时候,可以从数据库里提取数据,填充到对应的控件里。

    这个好像和05的表单控件差不多,不过有两个明显的区别。

    1、05的需要另外设置文本框这样的控件。

    2、使用DataSource这一类的控件来保存关联信息,而这些信息都是通过属性的方式设置,而且默认情况下是放在了aspx文件里面了。

    对于第一点呢,操作繁琐,当然也是很灵活;第二点嘛,就不好了。一两个页面的话,还好办,如果有100个这样的页面的话,那管理就是一个问题了。

    那么怎么实现我想要的效果呢,我采用自定义控件的方式来实现。

    1、先定义一个结构(好像也可以使用类)。

    2、根据属性添加子控件,也就是具体的控件(比如文本框、下拉列表框等)。

    3、取值,保存数据。

    4、修改的时候显示数据。

    [具体实现]

    1、先定义一个结构(好像也可以使用类)。

[Serializable()] public struct ControlInfos
    {
        /// <summary>
        /// 字段名称
        /// </summary>
        public string ColSysName;   

        /// <summary>
        /// 中文名称
        /// </summary>
        public string ColName;
        
        /// <summary>
        /// 控件类别
        /// </summary>
        public string ControlKind;
        
        /// <summary>
        /// 描述信息
        /// </summary>
        public string ColInfo;

    }

    2、根据属性添加子控件,也就是具体的控件(比如文本框、下拉列表框等)。

protected override void CreateChildControls()
        {
            base.CreateChildControls();
            ShowData();
        }
 public string ShowData()
        {
            foreach (ControlInfos info in this.CtrlInfo)
            {
                switch (info.ControlKind)
                {
                    case "":     //单行文本框
                        TextBox txt = new TextBox();
                        txt.ID = "c_" + info.ColSysName ;
                        this.Controls.Add(new LiteralControl(info.ColName ));
                        this.Controls.Add(txt);
                        this.Controls.Add(new LiteralControl("<BR>"));
                        break;

                    case "":     //下拉列表框
                        DropDownList lst = new DropDownList();
                        lst.ID = "c_" + info.ColSysName;
                        //lst.Items.Clear();
                        lst.Items.Add(new ListItem("测试项目1", ""));
                        lst.Items.Add(new ListItem("测试项目2", ""));
                       
                        this.Controls.Add(new LiteralControl(info.ColName));
                        this.Controls.Add(lst);
                        this.Controls.Add(new LiteralControl("<BR>"));
                        break;

                }
            }

            return "";

        }

    3、取值,保存数据。

public string SaveDate()
        {
            //调用数据访问函数库来保存数据
            ControlInfos[] info = this.CtrlInfo;

            string[] str1 = new string[info.Length];
            string[] str = new string[info.Length];
            for (int i = ; i < info.Length; i++)
            {
                str1[i] = info[i].ColSysName;

                switch (info[i].ControlKind)
                {
                    case "":
                        TextBox txt = new TextBox();
                        txt = (TextBox)this.FindControl("c_" + info[i].ColSysName);
                        str[i] = txt.Text.Trim().Replace("'","");
                        break;

                    case "":
                        DropDownList lst = new DropDownList();
                        lst = (DropDownList)this.FindControl("c_" + info[i].ColSysName);
                        str[i] = lst.SelectedValue ;
                        break;
                }
            }

            //测试输出
            for (int i = ; i < info.Length; i++)
            {
                base.Page.Response.Write(str1[i]);
                base.Page.Response.Write(":");
                base.Page.Response.Write(str[i]);
                base.Page.Response.Write("<BR>");

            }

            return "";

        }

    4、修改的时候显示数据。

        这个部分还没有写呢,不过也是类似的方法。

    5、调用。

protected void Page_Load(object sender, EventArgs e)
    {
        Response.Cache.SetNoStore();

        //设置控件的属性
        if (!Page.IsPostBack)
        {
            ControlInfos[] info = new ControlInfos[];
            info[].ColSysName = "NewsName";
            info[].ColName = "新闻标题";
            info[].ControlKind = "";

            info[].ColSysName = "NewsKind";
            info[].ColName = "新闻分类";
            info[].ControlKind = "";

            this.myForm.CtrlInfo = info;
        }
    }

    protected void Button1_Click(object sender, EventArgs e)
    {
        myForm.SaveDate();
    }

    缺点。说到缺点嘛,由于这里只是一个雏形,所以缺点是很多的,但是这里写的就是一个“核心”代码,关键代码都在这里面。其他的就是在这个基础上去完善、扩展、优化和美化 。

    1、case 。对控件判断的地方使用了case ,目前也没有其他的更好的方法。

    2、case 里面的代码。这里只是两种控件,最简单的代码,就已经好几行了,多了就不可想象了。虽然case 没有什么办法解决,但是case 里的代码,可以使用接口的方式来分散开。

        就是定义一个接口,在继承系统的控件(比如文本框)实现这个接口,然后表单控件里case的代码就可以简化很多了。

    3、调用的时候需要设置一个结构数组,这个是很烦的,代码行数也是很多的,好像还没有直接设置控件(文本框等)来得方便。对于这一点,我是把这些属性放在了一个配置文件(xml或者数据库)里面,然后在表单控件内部读取属性,自己就可以幅值了,外部只需要设置一个“编号”就可以了(告诉控件读取哪些信息)。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 表单控件续(1)——应用接口来简化和分散代码

    上次有点仓促,有几个地方没有明确。 后者是整个流程,前者是其中的一个步骤,是一个简单的思路说明,其中前三段代码都是表单控件里面的。 2、我要写的是一个表单控...

    用户1174620
  • 自然框架,拆分后的项目关系

      拆分了一下自然框架,似乎又绕回去了。以前是多个项目分开放的,有人说太分散了,还得一个个下载,麻烦。于是就做了一个解决方案,把项目都放在了一起。   现在呢,...

    用户1174620
  • 【开源】QuickPager ASP.NET2.0分页控件V2.0.0.3 【增加了使用说明】

    最新版本:V2.0.0.7 。http://www.cnblogs.com/jyk/archive/2008/07/28/1255101.html 下载:ht...

    用户1174620
  • python try语句如何打印错误行(

    py3study
  • [ISUX譯]Touch bar 設計指南

    腾讯ISUX
  • 跟成功人士学什么

    用户1756920
  • [WPF自定义控件]从ContentControl开始入门自定义控件

    我去年写过一个在UWP自定义控件的系列博客,大部分的经验都可以用在WPF中(只有一点小区别)。这篇文章的目的是快速入门自定义控件的开发,所以尽量精简了篇幅,更深...

    dino.c
  • 零基础学习Swift中的数据科学

    Python被广泛认为是数据科学中最好、最有效的语言。近年来我遇到的大多数调查都将Python列为这个领域的领导者。

    磐创AI
  • 11. Vue 中通过v-bind属性绑定为元素,设置class类样式

    因为v-bind的绑定的内容是js表达式,所以传递的参数是一个字符串数组([ 'red', 'thin', 'italic', 'active' ]),浏览器显...

    Devops海洋的渔夫
  • vue-cli引入vue-router

    同时在导航栏上方会有几个按钮,可以添加新的插件,如果我们之前没有安装过router插件,则会显示该按钮,点击安装即可。

    宣言言言

扫码关注云+社区

领取腾讯云代金券