Home  >  Article  >  Web Front-end  >  Implement global validation under bootstrapValidator based on jQuery_jquery

Implement global validation under bootstrapValidator based on jQuery_jquery

WBOY
WBOYOriginal
2016-05-16 15:27:161047browse

BootstrapValidator is a form inspection jQuery plug-in specifically for Boostrap v3. It can implement many commonly used inspection functions, is easy to expand, and also supports Chinese! It can be used out of the box for bootstrap users.

Prefix:

Introducing jQuery, bootstrap, bootstrapValidator

Problem description:

The project requires that the & symbol cannot be entered in all form input boxes. I didn’t find any method available in bootstrap, so I had to do it myself

Thinking:

Use regular expressions.

There are two situations. The first one is that if the input box has its own regular verification, you don’t need to worry about it (generally speaking, regular verification is used to strictly control the input); the second one is that if there is no regular expression, you need to add that you cannot input. &'s regular rule.

It is necessary to overload the bootstrapValidator initialization function and correct the initialization settings according to the above two situations. Finally, restore the original bootstrapValidator function (this step is necessary, the original bootstrapValidator function has a lot of associated stuff of its own, which cannot be lost);

Implementation:

/*add chenhua 2015.10.16 重写bootstrapValidator方法?给每一个验证项都添加禁止输入"&"符号*/ 
$(function(){  //保存原始的bootstrapValidator 
  var overwrite = $.fn.bootstrapValidator;   //重载bootstrapValidator
  $.fn.bootstrapValidator = function(options){ 
    //恢复原来的bootstrapValidator,因为其加了很多数据是不能丢失的 
    $.fn.bootstrapValidator = overwrite; 
            //这里有两种做法,第一种是直接修改arguments内容,使其包含不能输入&的验证,然后调用即可;    //第二种是先使用arguments来初始化,然后使用调用bootstrapValidator的函数来给非正则表达式验证的项添加不能输入&的验证    //这里我们使用了第二中。  
    var validtor = overwrite.apply(this,arguments); 
    if($.type(arguments[0]) == "object"){ 
      var vtor = this.data("bootstrapValidator"),      //过滤出输入框表单项   
      fileds = this.find("input[name][type='hidden'],input[name][type='password'],input[name][type='text'],textarea[name]").not(":disabled,[type='hidden']"); 
      fileds.each(function(){ 
        //本身没有正则验证才添加不能输入&的验证 
        if(!vtor.getOptions($(this).attr('name'),'regexp','regexp')){ 
         vtor.addField($(this).attr('name'), 
            { 
              validators: { 
                regexp: { 
                  regexp: /^[^&]*$/, 
                  message: "不能包含&字符" 
                } 
              } 
          }) 
        } 
      }) 
    } 
    return validtor; 
  } 
}) 

The above content is the global verification under bootstrapValidator based on jQuery introduced by the editor of Script House. I hope you like it.

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn