我佛山人的 1.04的验证JS, 。现在有个需求不知道不知道怎么弄? 能帮弄下?谢谢。
如:
<input name="a" datatype="mobile">
<input name="b" datatype="phone">
要求两者必须输入其一即可(两个都输入也可以),并且要相应的datatype验证。这个一直不知道怎么弄。

解决方案 »

  1.   

    定义一个变量 默认false  其中一个验证通过即为true
    提交时检验这个变量是否为true
    你外部的验证js只管验证该项是否符合 
    但具体怎么提交有客户决定
    要不你的验证js基本上没什么重用的价值了
      

  2.   

    或者再定义一个自定义属性 group  验证时查看有没有和这个属性相同的元素验证通过了的
      

  3.   

    谢谢。不太懂JS。
    他代码是这样的:
    // JavaScript Document
    Validator = {
    Require : /.+/,
    Cnt: /.{25,}/,
    Allstype: /.{2,}/,
    Email : /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/,
    Phone : /^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,8}(\-\d{1,4})?$/,
    Mobile : /^((\(\d{2,3}\))|(\d{3}\-))?[1-1]+[3-5]+\d{9}$/,
    Url : /^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$/,
    IdCard : /^\d{15}(\d{2}[A-Za-z0-9])?$/,
    Currency : /^\d+(\.\d+)?$/,
    Number : /^\d+$/,
    Singlenum : /^(\.[1-9]|1)$/,
    SingleNumber : /^(0\.[1-9]|1)$/,
    ColorFmt :  /^\#[0-9a-fA-F]{6}$/, 
    Zip : /^[1-9]\d{5}$/,
    QQ : /^[1-9]\d{4,15}$/,
    Integer : /^[-\+]?\d+$/,
    Double : /^[-\+]?\d+(\.\d+)?$/,
    English : /^[A-Za-z]+$/,
    Chinese :  /^[\u0391-\uFFE5]+$/,
    ExtTs: /^[^`~!@#$%^&*()+=|\\\][\]\{\}:;'\,.<>/?]{2}[^`~!@$%^&()+=|\\\][\]\{\}:;'\,.<>?]{0,19}$/,
    Username : /^[A-Za-z0-9]\w{2,29}$/i,
    NewUserName : /^[A-Za-z0-9]\w{2,29}$/i,
    NewPass : /^[A-Za-z0-9]\w{5,19}$/,
    UnSafe : /^(([A-Z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\'\"]*)|.{0,5})$|\s/,
    IsSafe : function(str){return !this.UnSafe.test(str);},
    SafeString : "this.IsSafe(value)",
    Filter : "this.DoFilter(value, getAttribute('accept'))",
    Limit : "this.limit(value.length,getAttribute('min'),  getAttribute('max'))",
    LimitB : "this.limit(this.LenB(value), getAttribute('min'), getAttribute('max'))",
    Date : "this.IsDate(value, getAttribute('min'), getAttribute('format'))",
    Repeat : "value == document.getElementsByName(getAttribute('to'))[0].value",
    Range : "getAttribute('min') <= (value|0) && (value|0) <= getAttribute('max')",
    Compare : "this.compare(value,getAttribute('operator'),getAttribute('to'))",
    Custom : "this.Exec(value, getAttribute('regexp'))",
    Group : "this.MustChecked(getAttribute('name'), getAttribute('min'), getAttribute('max'))",
    ErrorItem : [document.forms[0]],
    ErrorMessage : ["Tips锛歕t\t\t\t"],
    Validate : function(theForm, mode){
    var obj = theForm || event.srcElement;
    var count = obj.elements.length;
    this.ErrorMessage.length = 1;
    this.ErrorItem.length = 1;
    this.ErrorItem[0] = obj;
    for(var i=0;i<count;i++){
    with(obj.elements[i]){
    var _dataType = getAttribute("dataType");
    if(typeof(_dataType) == "object" || typeof(this[_dataType]) == "undefined")  continue;
    this.ClearState(obj.elements[i]);
    if(getAttribute("require") == "false" && value == "") continue;
    switch(_dataType){
    case "Date" :
    case "Repeat" :
    case "Range" :
    case "Compare" :
    case "Custom" :
    case "Group" : 
    case "Limit" :
    case "LimitB" :
    case "SafeString" :
    case "Filter" :
    if(!eval(this[_dataType])) {
    this.AddError(i, getAttribute("msg"));
    }
    break;
    default :
    if(!this[_dataType].test(value)){
    this.AddError(i, getAttribute("msg"));
    }
    break;
    }
    }
    }
    if(this.ErrorMessage.length > 1){
    mode = mode || 1;
    var errCount = this.ErrorItem.length;
    switch(mode){
    case 2 :
    for(var i=1;i<errCount;i++)
    this.ErrorItem[i].style.color = "blue";
    case 1 :
    alert(this.ErrorMessage.join("\n"));
    this.ErrorItem[1].focus();
    break;
    case 3 :
    for(var i=1;i<errCount;i++){
    try{
    var span = document.createElement("SPAN");
    span.id = "__ErrorMessagePanel";
    span.style.color = "red";
    this.ErrorItem[i].parentNode.appendChild(span);
    span.innerHTML = this.ErrorMessage[i].replace(/\d+:/,"  ");
    }
    catch(e){alert(e.description);}
    }
    this.ErrorItem[1].focus();
    break;
    default :
    alert(this.ErrorMessage.join("\n"));
    break;
    }
    return false;
    }
    return true;
    },
    limit : function(len,min, max){
    min = min || 0;
    max = max || Number.MAX_VALUE;
    return min <= len && len <= max;
    },
    LenB : function(str){
    return str.replace(/[^\x00-\xff]/g,"**").length;
    },
    ClearState : function(elem){
    with(elem){
    if(style.color == "blue")
    style.color = "";
    var lastNode = parentNode.childNodes[parentNode.childNodes.length-1];
    if(lastNode.id == "__ErrorMessagePanel")
    parentNode.removeChild(lastNode);
    }
    },
    AddError : function(index, str){
    this.ErrorItem[this.ErrorItem.length] = this.ErrorItem[0].elements[index];
    this.ErrorMessage[this.ErrorMessage.length] = this.ErrorMessage.length + ":" + str;
    },
    Exec : function(op, reg){
    return new RegExp(reg,"g").test(op);
    },
    compare : function(op1,operator,op2){
    switch (operator) {
    case "NotEqual":
    return (op1 != op2);
    case "GreaterThan":
    return (op1 > op2);
    case "GreaterThanEqual":
    return (op1 >= op2);
    case "LessThan":
    return (op1 < op2);
    case "LessThanEqual":
    return (op1 <= op2);
    default:
    return (op1 == op2);            
    }
    },
    MustChecked : function(name, min, max){
    var groups = document.getElementsByName(name);
    var hasChecked = 0;
    min = min || 1;
    max = max || groups.length;
    for(var i=groups.length-1;i>=0;i--)
    if(groups[i].checked) hasChecked++;
    return min <= hasChecked && hasChecked <= max;
    },
    DoFilter : function(input, filter){
    return new RegExp("^.+\.(?=EXT)(EXT)$".replace(/EXT/g, filter.split(/\s*,\s*/).join("|")), "gi").test(input);
    },
    IsDate : function(op, formatString){
    formatString = formatString || "ymd";
    var m, year, month, day;
    switch(formatString){
    case "ymd" :
    m = op.match(new RegExp("^((\\d{4})|(\\d{2}))([-./])(\\d{1,2})\\4(\\d{1,2})$"));
    if(m == null ) return false;
    day = m[6];
    month = m[5]*1;
    year =  (m[2].length == 4) ? m[2] : GetFullYear(parseInt(m[3], 10));
    break;
    case "dmy" :
    m = op.match(new RegExp("^(\\d{1,2})([-./])(\\d{1,2})\\2((\\d{4})|(\\d{2}))$"));
    if(m == null ) return false;
    day = m[1];
    month = m[3]*1;
    year = (m[5].length == 4) ? m[5] : GetFullYear(parseInt(m[6], 10));
    break;
    default :
    break;
    }
    if(!parseInt(month)) return false;
    month = month==0 ?12:month;
    var date = new Date(year, month-1, day);
    return (typeof(date) == "object" && year == date.getFullYear() && month == (date.getMonth()+1) && day == date.getDate());
    function GetFullYear(y){return ((y<30 ? "20" : "19") + y)|0;}
    }
    }
    function seashowtip(tips,flag,iwidth){
    var my_tips=document.all.mytips;
    if(flag){
    my_tips.innerHTML=tips;
    my_tips.style.display="";
    my_tips.style.width=iwidth;
    my_tips.style.left=event.clientX+1+document.body.scrollLeft;
    my_tips.style.top=event.clientY+1+document.body.scrollTop;
    }
    else
    {
    my_tips.style.display="none";  
    }
    }
      

  4.   

    描述有点纠结,你就说至少输入一个就很准确了用组件不好使,那自己写个代码验证不就得了
    按单个的验证格式,都允许为空
    然后写代码判断下文本框value
    if(!document.forms[0].a.value && !document.forms[0].b.value){
        alert('xx和xx至少填写一个');
    }