基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)

基类、接口的一种应用。目的呢就是要做一个表单控件,减少大部分代码。 另外呢是不是能借此机会区分一下基类和接口呢? 在另外一下,感觉我用的这个方法和策略模式有点像。 应用环境:VS2003 、webform。

基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)好久没发帖子了,又加了不少的功能呀。(图片仅是测试,不代表什么表情。)

本来我也想写一个2007的总结的,但是看到很多人都写了,我就不凑热闹了,写点和代码有关系的吧。

写作原因:
1、在项目里做得最多的操作恐怕就是保存数据了,总是要写一大堆的代码,能不能简单一点呢?2005来了,似乎可以减少一些代码,但是03里怎么办呢?
2、基类、接口、策略模式,好多高手都讨论过了,但是都是理论上的,在实践中如何应用呢?在webform 里面又怎么使用呢?

目的:
1、做一个“控件”来应对各种表单的录入,包括一次保存一条记录、一次保存多条记录。
2、写一下我对基类、接口、策略模式的理解,请各位高手批批。通过对一个实际中的例子的讨论,可以让新同学更好的理解吧。

针对的框架:
目前只考虑 asp.net1.1  (webform)。

先贴个图片,就是这样的表单
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)


[开始了]

1、取值问题
表单里会有很多种控件,每一种控件的取值方法又不太一致,有的叫做 “Text”,有的叫做“SelectedValue”,甚至有的还要自己在写几行代码才行(比如 CheckBoxList)。

那么怎么才能让取值更简单一点呢?我想写一个方法(GetValue)来获取用户输入的数据,而且在取值的时候不必关心是什么控件,一个GetValue,就把值得到了,管它是什么控件呢!

如果用基类的话就要在控件的“共有”基类里面加一个方法,但是这个“共有”的基类也不是太好找,再有呢在.net框架里加点东东好像也不是太容易(或者是我学艺不精)。

我想到的解决方法呢就是使用接口。

先定义一个接口:IGetControlValue

 

基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)Public Interface IGetControlValueInterface IGetControlValue
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    ReadOnly Property ControlKind()Property ControlKind() As String
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    Function GetControlValue()Function GetControlValue() As String
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)End Interface

 然后呢再写几个自定义服务器控件(比如文本控件、下拉列表框了什么的),让他们继承这个接口。

目前我写了五个这样的控件:HBSTextBox 、HBSCheckBox 、HBSCheckBoxList 、HBSDropDownList 、HBSRadioButtonList 
他们都继承了IGetControlValue。

控件比较多,我就只贴出 HBSCheckBoxList 的代码吧,其他的都是类似的写法。

基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)<ToolboxData("")> _
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上) Public Class HBSCheckBoxListClass HBSCheckBoxList
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    Inherits System.Web.UI.WebControls.CheckBoxList
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    Implements IGetControlValue
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)实现接口#Region "实现接口"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    <Bindable(True), Category("默认值"), DefaultValue("210"), Description("获取控件类别")> _
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    ReadOnly Property ControlKind()Property ControlKind() As String Implements IGetControlValue.ControlKind
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Get
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            Return "210"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        End Get
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    End Property
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    Public Function GetValue()Function GetValue() As String Implements IGetControlValue.GetControlValue
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Return Me.GetSelectedValue
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    End Function
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)#End Region
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)初始化 OnInit。设置CssClass、DataValueField、DataTextField、#Region "初始化 OnInit。设置CssClass、DataValueField、DataTextField、"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    Protected Overrides Sub OnInit()Sub OnInit(ByVal e As EventArgs)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Me.CssClass = "chk"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Me.DataValueField = "ID"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Me.DataTextField = "txt"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Me.Font.Size = FontUnit.Point(9)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    End Sub
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)#End Region
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    '返回选择的ID值,用 , 分隔
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)函数实现  GetSelectedValue#Region "函数实现  GetSelectedValue"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    Public Function GetSelectedValue()Function GetSelectedValue() As String
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Dim item As ListItem
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Dim tmpStr As String = ""
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        For Each item In Me.Items
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            If item.Selected Then
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                tmpStr &= item.Value & ","
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            End If
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Next
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        tmpStr = tmpStr.TrimEnd(",")
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Return tmpStr
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    End Function
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)#End Region
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)


(什么?您问为什么还有一个 GetSelectedValue(),没办法,这个是以前就实现了的,接口是后加的,为了保持向下兼容)

 好了取值的问题基本解决了。


2、寻找控件。

如果加了接口之后还是 this.Txt1.GetValue(); 或者  ((IGetControlValue)Txt1).GetControlValue();那就没什么意思了。
我想达到的是  ((IGetControlValue)Page.FindControl("控件ID")).GetControlValue();

这样做的好处是我只要知道控件的ID就可以得到数据,而不必去关心到底是什么控件,取值上有没有什么特殊的地方。
另外呢我还可以做一个循环,把控件ID放到一个数组里面,然后循环一下就可以了。控件(字段)再多我也不怕了,代码行数不会跟随字段的增加而增加。


3、开始保存数据(单条数据)。
在这里呢建议先看一下我以前发的一个帖子。
其实添加数据也可以这样简单——表单的第一步抽象(针对数据访问层)《怪怪设计论: 抽象无处不在 》有感

具体代码如下:

基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)添加数据#region 添加数据
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        private void Btn_Save2_Click(object sender, System.EventArgs e)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        {
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            //设置字段名
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            string[] str1 = new string[5];
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            str1[0] = "TextBox";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            str1[1] = "CheckBox";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            str1[2] = "RadioButtonList";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            str1[3] = "CheckBoxList";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            str1[4] = "DropDownList";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            //设置控件ID
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            string[] str2 = new string[5];
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            str2[0] = "Txt2";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            str2[1] = "Chk2";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            str2[2] = "rdLst2";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            str2[3] = "chkLst2";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            str2[4] = "Lst2";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            //取值用的数组
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            string[] str = new string[5];
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            HBS.Controls.IGetControlValue vv ;
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            for (int i=0 ;i<str1.Length ;i++)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            {
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                vv = (IGetControlValue)base.GetControl(str2[i],-2);
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                str[i] = vv.GetControlValue();
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            }
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            //添加数据
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            dal.InsertDataStr("_TestInterface",str1,str);
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            //弹出提示
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            Functions.PageRegisterAlert(Page,"添加成功");
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        }
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        #endregion

(自我感觉还是挺简洁的,dal.InsertDataStr("_TestInterface",str1,str); 是调用数据访问层里的函数,而这个“数据访问层”是通用的,已经编译成dll,可以随时调用)。


4、保存多条数据。

上面说的是一次保存一条数据,那么要一次保存多条怎么办呢?这里需要DataGrid来帮忙了。
拖一个DataGrid出来,然后做一下设置,加几个模版类。


然后呢保存代码如下:

基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)一次修改多条数据#region 一次修改多条数据
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        private void Btn_Save_Click(object sender, System.EventArgs e)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        {
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            //保存数据
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            FormTableCntrlInfo[] cInfo = new FormTableCntrlInfo[5];
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[0].FieldName = "TextBox";        //设置字段名
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[1].FieldName = "CheckBox";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[2].FieldName = "RadioButtonList";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[3].FieldName = "CheckBoxList";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[4].FieldName = "DropDownList";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[0].ControlID = "Txt1";        //设置控件ID
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[1].ControlID = "Chk1";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[2].ControlID = "rdLst";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[3].ControlID = "chkLst";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[4].ControlID = "Lst";
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            //设置控件的列索引,就是控件在DataGrid的第几行。
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[0].ColumnIndex = 1;        
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[1].ColumnIndex = 2;
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[2].ColumnIndex = 3;
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[3].ColumnIndex = 4;
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            cInfo[4].ColumnIndex = 5;
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            FormTableSaveData form = new FormTableSaveData();
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            form.dal = dal;                        //设置数据访问层的实例
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            form.TableName = "_TestInterface";    //设置表名
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            string err = form.SaveDataByDataGrid(ref DG,ref cInfo,"testID={0}");  //修改数据
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            if (err.Length >2)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            {
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                Functions.PageRegisterAlert(Page,"保存时出现以外,请与管理员联系。");
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                return;
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            }
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            Functions.PageRegisterAlert(Page,"保存成功");
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        }
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        #endregion

这里保存了五个字段的记录,怎么样代码不是太多吧。
最大的优点就是:当控件在DataGrid的列的位置发生变化的时候,修改是很方便的。

什么?您问取值的地方在哪里?已经被我封装起来了。
form.SaveDataByDataGrid 是一个 针对DataGrid 来说通用的方法,只要你是用DataGrid来“绘制”页面的话就可以使用这个方法,不必每次(或每个项目)都写一遍。


还是贴一下  SaveDataByDataGrid 的代码吧。

基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)Public Class FormTableSaveDataClass FormTableSaveData
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    Public dal As DataAccessLayer           '数据访问层
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    Public TableName As String = ""         '添加、修改用的表名
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)保存DataGrid里的全部数据#Region "保存DataGrid里的全部数据"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    Public Function SaveDataByDataGrid()Function SaveDataByDataGrid(ByRef DG As DataGrid, ByRef cInfo() As FormTableCntrlInfo, ByVal Query As String) As String
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Dim item As DataGridItem
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        For Each item In DG.Items
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            If item.ItemType <> ListItemType.Header And item.ItemType <> ListItemType.Footer Then
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                SaveDataByDataGridItem(item, cInfo, Query)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            End If
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Next
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    End Function
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)#End Region
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)保存DataGrid里的一条数据#Region "保存DataGrid里的一条数据"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    Public Function SaveDataByDataGridItem()Function SaveDataByDataGridItem(ByRef item As DataGridItem, ByRef cInfo() As FormTableCntrlInfo, ByVal Query As String) As String
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Dim i As Int32
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Dim tmpIndex As Int32
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Dim ctrlIndex As Int32 = 0
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Dim iValue As IGetControlValue
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        For i = 0 To item.Cells.Count - 1
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            '寻找对应的下标
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            ctrlIndex = -1
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            For tmpIndex = 0 To cInfo.Length - 1
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                If i = cInfo(tmpIndex).ColumnIndex Then
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                    ctrlIndex = tmpIndex
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                    Exit For
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                End If
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            Next
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            If ctrlIndex > -1 Then
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                Select Case cInfo(ctrlIndex).ControlKind
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                    Case "201", "202", "203", "204", "205", "208", "209", "210"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        '文本框、多行文本、密码、日期文本、下拉列表 、复选框、单选组、多选组
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        '"201",  "202",   "203",  "204",   "205",    "208",   "209",   "210"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        iValue = item.Cells(cInfo(ctrlIndex).ColumnIndex).FindControl(cInfo(ctrlIndex).ControlID)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        If iValue Is Nothing Then
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            PublicClass.ResponseWrite("没有找到[" & cInfo(ctrlIndex).ControlID & "]这个控件", False)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        Else
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            cInfo(ctrlIndex).FieldValue = iValue.GetControlValue()
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        End If
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                    Case "206"      ' 级联下拉列表()  
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        Dim tmpSplit(1) As Char
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        tmpSplit(0) = "|"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        tmpSplit(1) = ","
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        Dim uLst As UniteDropDownList = CType(item.Cells(cInfo(ctrlIndex).ColumnIndex).FindControl(cInfo(ctrlIndex).ControlID), UniteDropDownList)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        If uLst Is Nothing Then
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            PublicClass.ResponseWrite("没有找到[" & cInfo(ctrlIndex).ControlID & "]这个控件", False)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        Else
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            Dim myID() As String = uLst.ListOtherSelectedValue.Split(tmpSplit)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            Dim j As Int32 = 0
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            For j = 0 To myID.Length
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                                cInfo(i).FieldValue = myID(j)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                                ctrlIndex += 1
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                                i += 1
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            Next
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            ctrlIndex -= 1
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            i -= 1
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        End If
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        'Case "207"      ' 单选()
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                    Case "211"      ' HTML_FreeTextBox() 
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        Dim ftb As FreeTextBoxControls.FreeTextBox = CType(item.Cells(cInfo(ctrlIndex).ColumnIndex).FindControl(cInfo(ctrlIndex).ControlID), FreeTextBoxControls.FreeTextBox)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        If ftb Is Nothing Then
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            PublicClass.ResponseWrite("没有找到[" & cInfo(ctrlIndex).ControlID & "]这个控件", False)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        Else
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            cInfo(ctrlIndex).FieldValue = ftb.Text
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            cInfo(ctrlIndex).FieldValue = cInfo(ctrlIndex).FieldValue.Replace("'", "''")
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                            cInfo(ctrlIndex).FieldValue = cInfo(ctrlIndex).FieldValue.Replace("script", "script")
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        End If
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                    Case "212"      ' HTML_CuteEdit()
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                    Case "213"  '空行
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                        cInfo(ctrlIndex).FieldValue = "_n_"
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                End Select
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)                ctrlIndex += 1
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            End If
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Next
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        '取值结束,保存数据
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Dim aa As Int32
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Dim tmpQuery = Query
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        For aa = 0 To Query.Split("{").Length - 2
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)            tmpQuery = tmpQuery.Replace("{" & aa & "}", item.Cells(aa).Text)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Next
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        'Query = Query.Replace("{0}", item.Cells(0).Text)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        ' PublicClass.ResponseWrite(tmpQuery & "
", False)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        dal.UpdateDataByFormTableCntrlInfo(TableName, cInfo, tmpQuery)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)        Return dal.ErrorMsg
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)    End Function
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)#End Region
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)End Class

这样就基本OK了。今天刚刚写好,可能会有一些错误,另外还有一个问题没有说,还有几个延伸的地方。放在下集在说吧。

(上集完成)


上一篇:stm32 中断 和事件


下一篇:linux安装mysql数据库