zoukankan      html  css  js  c++  java
  • 网页中控件智能校验的一种实现方法(原创)

           在Web项目中控件值的校验是不可少的,对于有大量控件的页面,程序员通常要使用Javascript编写大量的脚本进行,有没有一种方式可以减少程序员的这种大量重复编码的方式。最近,在一个项目中尝试了这种方式,大大的减少了前后台的校验代码的编写。

           此技术的实现并不复杂,只是实现了一种检验的思路,希望能给给大家起个抛砖引玉的作用。由于工作原因我使用ASP+JS实现,其实语言只是一种工具,关键是思路。当然,也可以用ASP.NET实现。

            本文是Javascript实现的自动验证函数(原创) 的续篇,那片文章里只实现了前台的校验。

    测试页面
    test.asp
    校验的内容:Text控件
    校验方式:单一控件和控件数组
    特殊属性的说明:
    valuetype="integer"   控件值的类型
     msg=",<%=IMSG0002%>"   错误信息
    第一项是必须输入项的提示信息;第二项是类型错误的提示信息,两项都可为空但中间的“,”号不能省略。
    mustitem="true"  必须输入项,没有这个属性的控件就认为不是必需输入项

     1<%
     2    Response.CharSet ="gb2312"
     3
    %>
     4<!-- #include file="message.inc" -->
     5<!-- #include file="stringtools.inc" -->
     6<!-- #include file="common.inc" -->
     7<!-- #include file="validate.inc" -->
     8<%
     9
    10    Dim strErrMsgID
    11    Call validate()
    12
    %>
    13<HTML>
    14<HEAD>
    15<TITLE> New Document </TITLE>
    16    <meta http-equiv="content-type" content="text/html; charset=gb2312" />
    17    <meta http-equiv="pragma" content="no-cache">
    18    <meta http-equiv="cache-control" content="no-cache">
    19    <meta http-equiv="expires" content="0">
    20<script src="common.js"></script>
    21<script src="validate.js"></script>
    22<script language="javascript">
    23<!--
    24function a(obj){
    25
    26    alert(obj.name);
    27}

    28//-->
    29
    </script>
    30</HEAD>
    31
    32<BODY>
    33<FORM NAME="frm" METHOD=POST ACTION="">
    34<font color="red"><%=strErrMsgID%></font>
    35<input type="hidden" id="_page_viewstate" name="_page_viewstate" value="">
    36ID<INPUT TYPE="text" id="txtInt" NAME="txtInt" maxlength="6" valuetype="integer" msg=",<%=IMSG0002%>" ><br>
    37ID<INPUT TYPE="text" id="txtInt" NAME="txtInt" maxlength="6" valuetype="integer" msg=",<%=IMSG0002%>" ><br>
    38ID<INPUT TYPE="text" id="txtInt" NAME="txtInt" maxlength="6" valuetype="integer" msg=",<%=IMSG0002%>" ><br>
    39ID<INPUT TYPE="text" id="txtInt" NAME="txtInt" maxlength="6" valuetype="integer" msg=",<%=IMSG0002%>" ><br>
    40
    41名称<INPUT TYPE="text" id="txtString" NAME="txtString" maxlength="5" valuetype="string" msg="<%=IMSG0003%>,<%=IMSG0004%>" mustitem="true"><br>
    42名称<INPUT TYPE="text" id="txtDate" NAME="txtDate" maxlength="10" valuetype="date" msg="<%=IMSG0003%>,werwe" mustitem="true"><br>
    43<INPUT TYPE="button" value="submit" onclick="validate(frm); return false;">
    44
    45<SCRIPT LANGUAGE="JavaScript">
    46<!--
    47//validate()
    48//-->
    49
    </SCRIPT>
    50</FORM>
    51</BODY>
    52</HTML>
    53


    后台检验validate.asp
    将前台传来的_page_viewstate参数通过分解得到,页面的校验信息
    ValueSeparator  页面控件信息分割符
    ItemSeparator   每个可能的参数分割符

     1<%
     2'-------------------------------------------------------------------
     3'* 函数名                :    validate
     4'* 完成日                :    2007/04/04
     5'* 更新日                :    2007/04/04
     6'* 作者                    :    向东   meil75#hotmail.com
     7'* 参数                    :    
     8'* 機能説明              :    前台参数的后台校验
     9'-------------------------------------------------------------------
    10Function validate()
    11
    12    Const ValueSeparator ="<<__>>"
    13    Const ItemSeparator ="<<==>>"
    14
    15    Dim strViewstate
    16    Dim arrayViewstate
    17    Dim arrayItem
    18    Dim i
    19    Dim intAVLen
    20    Dim strValue, strMaxlength, strValuetype, strMsg, strMustitem
    21
    22    validate = True
    23
    24    strViewstate = Request("_page_viewstate")
    25
    26
    27    If strViewstate <> "" Then
    28
    29        arrayViewstate = split(strViewstate, ValueSeparator)
    30        intAVLen = UBound(arrayViewstate)
    31
    32        For i = 0 To intAVLen
    33
    34            arrayItem = split(arrayViewstate(i), ItemSeparator)
    35
    36            If UBound(arrayItem) = 6 Then
    37
    38                strValue = Trim(arrayItem(1))
    39                strMaxlength = arrayItem(2)
    40                strValuetype = LCase(arrayItem(3))
    41                strMustitem = LCase(arrayItem(5))
    42
    43                strMsg = split(arrayItem(4), ",")
    44
    45                '是否是必须输入项
    46                If strMustitem = "true" And strValue = "" Then
    47                    If (Instr(strErrMsgID,  strMsg(0)) <1Then
    48                        strErrMsgID = strErrMsgID + strMsg(0& "<br>"
    49                    End If
    50                    validate = False
    51                End If
    52
    53                '数值验证
    54                If strValue <> "" And strValuetype = "integer" And (Not CheckNum(strValue) Or Len(strValue) > strMaxlength)Then
    55                    If (Instr(strErrMsgID,  strMsg(1)) <1Then
    56                        strErrMsgID = strErrMsgID + strMsg(1& "<br>"
    57                    End If
    58                    validate = False
    59                End If
    60
    61                '文字校验
    62                If strValue <> "" And strValuetype = "string" And StrLenB(strValue) > CInt(strMaxlength) Then
    63                    If (Instr(strErrMsgID,  strMsg(1)) <1Then
    64                        strErrMsgID = strErrMsgID + strMsg(1& "<br>"
    65                    End If
    66                    validate = False
    67                End If
    68
    69                '日期校验
    70                If strValue <> "" And strValuetype = "date" And isDateValue(strValue) = False Then
    71                    If (Instr(strErrMsgID,  strMsg(1)) <1Then
    72                        strErrMsgID = strErrMsgID + strMsg(1& "<br>"
    73                    End If
    74                    validate = False
    75                End If
    76
    77                'Response.Write(strValue & "____" & strMaxlength & "____" & strValuetype & _
    78                '"____" & strMsg(0) & "____" & strMsg(1) & "____" & strMustitem & "<BR>")
    79
    80            End If
    81        Next
    82
    83    End If
    84
    85End Function
    86%>


    前台JavaScript校验 validate.js
    实现单一控件和控件数组的校验
    将控件值和校验属性通过_page_viewstate 参数传递到后台,有点类似ASP.NET里的viewstate。不过这回你可以自己决定它的内容和封装形式了。这可能是也是程序员在编程中最大的诉求了,自己掌握了程序的控制权,使程序的编写更加灵活。
    ValueSeparator  页面控件信息分割符
    ItemSeparator   每个可能的参数分割符

      1/******************************************************
      2* 函数名                :    validate
      3* 制作日                :    2007/04/05
      4* 更新日                :    2007/04/05
      5* 作者                    :    向东   meil75#hotmail.com
      6* 引数                     :    
      7* 機能説明              :     Text控件校验
      8******************************************************/

      9var controlArrayName;
     10var ValueSeparator ="<<__>>";
     11var ItemSeparator ="<<==>>";
     12function validate(){
     13
     14    var Elements;
     15    var i;
     16    var elLen
     17    var msgs;
     18    controlArrayName = "";
     19
     20    document.getElementById("_page_viewstate").value = "";
     21
     22    //var objs = document.all;
     23    //var Elements = document.getElementsByTagName("*");
     24    Elements = document.getElementsByTagName("input");
     25    arrName ="";
     26
     27    for ( i in Elements ) {
     28    elLen = Elements[i].length;
     29
     30        if (elLen > 1{
     31
     32            //数组控件的校验
     33            if (checkArrayValue(Elements[i]) == false{
     34                return false;
     35            }

     36
     37        }
    else{
     38
     39            //控件校验
     40            if (checkValue(Elements[i]) == false{
     41                return false;
     42            }

     43        }

     44    }

     45
     46    //var _frmObj = document.forms;
     47    //_frmObj[0].submit();
     48
     49    return true;
     50}

     51
     52/******************************************************
     53* 函数名                :    checkArrayValue
     54* 完成日                :    2007/04/05
     55* 更新日                :    2007/04/05
     56* 作者                    :    向东   meil75#hotmail.com
     57* 引数                  :    控件数组
     58* 機能説明              :    数组控件的校验
     59******************************************************/

     60function checkArrayValue( obj ){
     61
     62    var ctlArray;
     63    var j;
     64    var arrLen;
     65
     66    ctlArray = obj;
     67    arrLen = ctlArray.length;
     68
     69    if (controlArrayName != ctlArray[0].name.toLowerCase()) {
     70        controlArrayName = ctlArray[0].name.toLowerCase();
     71
     72        for (j=0; j < arrLen; j++{
     73
     74            //数组控件的校验
     75            if (checkValue(ctlArray[j]) == false{
     76                return false;
     77            }
     
     78        }

     79    }

     80
     81    return true;
     82}

     83
     84/******************************************************
     85* 函数名                :    checkValue
     86* 完成日                :    2007/04/05
     87* 更新日                :    2007/04/05
     88* 作者                    :    向东   meil75#hotmail.com
     89* 引数                    :    控件
     90* 機能説明              :   控件的校验
     91******************************************************/

     92function checkValue ( obj ){
     93
     94    var len;
     95    len = obj.maxLength;
     96
     97    if ( obj.type == "text" ) {
     98
     99        //if (obj.msg != undefined ) {
    100        if ( obj.msg ) {
    101            msgs = obj.msg.split(",");
    102        }
     else {
    103            return true;
    104        }

    105
    106        if ( trim(obj.value) == ""{
    107
    108            //是否是必须输入项
    109            if ( obj.mustitem && obj.mustitem.toLowerCase() == "true"{
    110
    111                alert(msgs[0]);
    112                getFocusSelect(obj);
    113                return false;
    114            }

    115
    116        }
    else {
    117
    118            //数字校验
    119            if ( obj.valuetype && obj.valuetype.toLowerCase() == "integer" ) {
    120
    121                if ( checkNumLen(trim(obj.value), len) == false ) {
    122                    alert(msgs[1]);
    123                    getFocusSelect(obj);
    124                    return false;
    125                }

    126
    127            //文字校验
    128            }
     else if ( obj.valuetype && obj.valuetype.toLowerCase() == "string" ) {
    129
    130                if ( getLenthByByte(trim(obj.value)) > len){
    131                    alert(msgs[1]);
    132                    getFocusSelect(obj);
    133                    return false;
    134                }

    135
    136            //日期校验
    137            }
     else if ( obj.valuetype && obj.valuetype.toLowerCase() == "date" ) {
    138
    139                if ( isDate(trim(obj.value)) == false){
    140                    alert(msgs[1]);
    141                    getFocusSelect(obj);
    142                    return false;
    143                }

    144            }

    145        }

    146
    147        //控件信息的保存
    148        var pvObj = document.getElementById("_page_viewstate");
    149        pvObj.value = pvObj.value + ValueSeparator + getCtlInfo(obj);
    150        //alert(pvObj.value);
    151    }

    152
    153    return true;
    154}

    155
    156/******************************************************
    157* 関数名                :    getCtlInfo
    158* 作成日                :    2007/04/05
    159* 更新日                :    2007/04/05
    160* 作成者                :    向东   meil75#hotmail.com
    161* 引数                  :    控件
    162* 機能説明              :    控件信息获得
    163******************************************************/

    164function getCtlInfo(obj) {
    165
    166    var strValue;
    167    var objMsg;
    168    var objMustitem;
    169
    170    strValue = obj.name + ItemSeparator + obj.value + ItemSeparator +
    171                  obj.maxLength + ItemSeparator + obj.valuetype +ItemSeparator;
    172
    173    if ( obj.msg ) {
    174        strValue = strValue + obj.msg;
    175    }

    176    strValue = strValue + ItemSeparator;
    177
    178    if ( obj.mustitem) {
    179        strValue = strValue + obj.mustitem;
    180    }

    181    strValue = strValue + ItemSeparator;
    182
    183    return strValue;
    184}


           本人是第一次作ASP的项目,对ASP也不是很精通,难免有不足之处。希望,各位能给予指正。

           下一步,我想用ASP。NET来实现不知道有没有时间了。总觉得。NET的脚本库太庞大了,比较笨重。在项目中使用不便,而且不够灵活。

    http

  • 相关阅读:
    js函数——倒计时模块+无缝滚动
    一步步编写avalon组件02:分页组件
    mvc5+ef6+Bootstrap 项目心得--身份验证和权限管理
    只用css实现“每列四行,加载完一列后数据自动填充到下一列”的效果
    某考试 T1 arg
    vijos 2035 奇数偶数与绚丽多彩的数
    bzoj 5093: [Lydsy1711月赛]图的价值
    [HEOI2016/TJOI2016]求和
    [TJOI2015]概率论
    Codeforces 616 E Sum of Remainders
  • 原文地址:https://www.cnblogs.com/meil/p/705993.html
Copyright © 2011-2022 走看看