如何切换函数的多个参数

时间:2010-11-08 20:32:43

标签: jquery conditional

请检查我的J Query程序。我在IF语句中有很多参数输入,那么它是否有任何方法可以切换每个参数?我目前的计划工作正常,但我需要更多的组合。例如,有四种组合,所以4 * 4 = 16组合每个IF所以有没有解决方案来最小化解析所有参数?

    e.g lower && upper && digit && special
    lower && special &&  upper && digit 
    upper && special &&  digit && upper 
    .
    .
    .
    special && digit && upper && lower

(function($) {

var LOWER = /[a-z]/,
    UPPER = /[A-Z]/,
    DIGIT = /[0-9]/,
    DIGITS = /[0-9].*[0-9]/,
    SPECIAL = /[^a-zA-Z0-9]/,
    SAME = /^(.)\1+$/;

function rating(rate, message) {
    return {
        rate: rate,
        messageKey: message
    };
}

function uncapitalize(str) {
    return str.substring(0, 1).toLowerCase() + str.substring(1);
}

$.validator.passwordRating = function(password, username) {

    if (!password || password.length < 5)
        return rating(0, "too-short");

    if (username && password.toLowerCase().match(username.toLowerCase()))
        return rating(0, "similar-to-username");

    if (SAME.test(password))
        return rating(1, "very-weak");

        var lower = LOWER.test(password),
        upper = UPPER.test(uncapitalize(password)),
        digit = DIGIT.test(password),
        digits = DIGITS.test(password),
        special = SPECIAL.test(password);



    if (lower && upper && digit && special && password.length > 19 || lower && upper && digits && special && password.length > 19 || special && upper && lower && digits && password.length > 19 || lower && special && upper && digits && password.length > 19 || lower && upper && special && digits && password.length > 19 || upper && lower && special && digits && password.length > 19)
        return rating(5, "very-strong");

    if (lower && upper && digit && special && password.length > 8 || lower && upper && digits && special && password.length > 8 || special && upper && lower && digits && password.length > 8 || lower && special && upper && digits && password.length > 8 || lower && upper && special && digits && password.length > 8 || upper && lower && special && digits && password.length > 8)
        return rating(4, "strong");

    if (lower && upper && digit && password.length > 5 || lower && upper && digits && password.length > 5|| upper && lower && digits && password.length > 5 || upper && lower && digit && password.length > 5 || digit && upper && lower && password.length > 5 ||  digits && upper && lower && password.length > 5 || upper && digit && lower && password.length > 5 || upper && digits && lower && password.length > 5)
        return rating(3, "good");
        return rating(2, "weak");

}

$.validator.passwordRating.messages = {
    "similar-to-username": "Too similar to username",
    "too-short": "Too short",
    "very-weak": "Very weak",
    "weak": "Weak",
    "good": "Good",
    "strong": "Strong",
    "very-strong": "Very Strong"
}

$.validator.addMethod("password", function(value, element, usernameField) {
    // use untrimmed value
    var password = element.value,
    // get username for comparison, if specified
        username = $(typeof usernameField != "boolean" ? usernameField : []);

    var rating = $.validator.passwordRating(password, username.val());
    // update message for this field

    var meter = $(".password-meter", element.form);

    meter.find(".password-meter-bar").removeClass().addClass("password-meter-bar").addClass("password-meter-" + rating.messageKey);
    meter.find(".password-meter-message")
    .removeClass()
    .addClass("password-meter-message")
    .addClass("password-meter-message-" + rating.messageKey)
    .text($.validator.passwordRating.messages[rating.messageKey]);
    // display process bar instead of error message

    return rating.rate > 2;
}, "&nbsp;");
// manually add class rule, to make username param optional
$.validator.classRuleSettings.password = { password: true };

  })(jQuery);

1 个答案:

答案 0 :(得分:0)

如何使用评分系统获得可接受的分数?

  var score = 5;

  if (!(lower && upper)) {
    score--;
  }
  if (passwordlength <= 8) {
    score--;
  }
  if (!digit) {
    score--;
  }

然后对于阻止者,就像没有密码匹配用户名一样,只是出现错误消息。