在国家/地区代码下拉添加所需的验证[intl-tel-input jquery plugin]

时间:2017-01-11 15:35:19

标签: javascript jquery plugins intl-tel-input

intl-tel-input plugin link

我正在使用此插件,我想在国家/地区代码下拉列表中添加所需的验证,但此插件不允许我这样做。

我尝试了但失败了。

首先,我在下拉点击事件

上添加所选课程
$(document).on('click', '.country', function () {
    $(".flag-dropdown").find('.selected-flag').addClass('selected');
});

然后我检查了div是否没有选择类然后在输入字段容器div中添加错误类

但它不能正常工作

$("input[name='mobile']").keypress(function () {
    var isSelected = $('.flag-dropdown').find('.selected-flag').hasClass('selected');
    if (isSelected == false) {
        $('.has-feedback').removeClass('has-success');
        $('.has-feedback').addClass('has-error'); 
    }
});

我也在使用bootstrap验证

      mobile: {
                validators: {
                    stringLength: {min: 8, message: " "},
                    notEmpty: {message: " "},
                    regexp: {regexp: /^\+?[\d-]+$/, message: " "}
                }
              }

任何帮助将不胜感激。!

1 个答案:

答案 0 :(得分:3)

我也使用过这个插件并遇到了同样的问题并通过这些步骤解决了

1 :为您的bootstrap验证添加回调函数

          mobile: {
                    validators: {
                        notEmpty: {message: " "},
                        regexp: {regexp: /^\+?[\d ]+$/, message: " "},
                        callback: {
                            message: '',
                            callback: function (value, validator, $field) {
                                if(!$('div.flag-dropdown').find('.country').hasClass('active')){
                                    return false;
                                }else{
                                    return true;
                                }
                            }
                        },
                    }
                },

2 :通过此代码更改您点击事件

$(document).on('click', '.country', function () {
    var selectCode = $('ul.country-list').find('.active').attr('data-dial-code');
    if($.type(selectCode ) === "string") {
        $('#contact_mobile').val('+' + selectCode);
    }else{
        $('#contact_mobile').val('');
    }
});