快速获取input以及具有name属性元素的value

//获取某个标签(formSelector)下所有具有name属性的value
//返回以标签的name属性值为key 对应其value的对象
function(formSelector) {
      var result = {
        passed: true,
        reason: ''
      };
      var curForm = $(formSelector);
      var inputsArr = curForm.find('*[data-validate]'),
          len = inputsArr.length;
          curInput, passed = true, type, inputVal, validateRule;
      for (var i = 0; i < len; i++) {
        curInput = $(inputsArr[i]);
        inputVal = curInput.val().trim();
        validateRule = JSON.parse(curInput.attr('data-validate'));
        for(var k in validateRule) {
          switch (validateRule[k]) {
            case 'required':
              if(!inputVal) {
                passed = false;
                type = 'required';
              }
              break;
            case 'phone':
              if(!(/^1[3456789]\d{9}$/.test(inputVal))){
                passed = false;
                type = 'phone';
              }
              break;
            case 'mail':
              if(!(/^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/.test(inputVal))){
                passed = false;
                type = 'mail';
              }
              break;
          }
          if(!passed) {
            result.passed = false;
            result.reason = this.validateText[type] || '验证未通过'
            return result;
          }
        }
      }
      return result;
    }

//给input标签赋值  
//values为一个对象 对象中的key必须与 formSelector标签下面具有name属性的标签的name值对应
 function(formSelector, values) { 
      var valueArr = $(formSelector).find('*[name]');
      if(!valueArr.length) {return};
      $.each(valueArr, function(index, ele) {
        switch (ele.tagName) {
          default:
              values[ele.name] && (ele.value = values[ele.name]);
            break;
        }
      })
    }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值