I tried every solution from articles one, two , three yet in my sample project, I can still enter a number or spec char in the first name field.
The six+ things I tried:
$.validator.setDefaults({ submitHandler: function(form) { form.submit(); } });
jQuery.validator.addMethod("regex", function(value, element, param) { return value.match(new RegExp("^" + param + "$")); });
var ALPHA_REGEX = "[a-zA-Z]*";
jQuery.validator.addMethod("accept", function(value, element, param) {
  return value.match(new RegExp("." + param + "$"));
});
function isValid(value)
{
  var fieldNum = /^[a-z]+$/i;
  if ((value.match(fieldNum))) {
      return true;
  }
  else
  {
      return false;
  }
}
  $(document).ready(function() {
    $('#contact_form').bootstrapValidator({
                  fields: {
            first_name: 
            {
                validators: {
                field: { accept: "[a-zA-Z]+" },
                regex: ALPHA_REGEX,
                 lettersonly:true,
                required: true,
                pattern: "^[a-zA-Z_]*$",
                        stringLength: {
                        min: 2,
                    },
                        notEmpty: {
                        message: 'Please supply your first name',
                        callback: function(value, validator, $field) {
                            if (!isValid(value)) {
                              return {
                                valid: false,
                              };
                            }
                            else
                            {
                              return {
                                valid: true,
                              };    
                    }
                }
            },
I am sure I am missing something simple or possibly using a slightly outdated jQuery Library? EDIT: I actually just tried using other versions of the library to no success.
 
    