效果图及代码如下:<html xmlns="http://www.w3.org/1999/xhtml"><head runat="server"> <title></title> <style type="text/css">.password {font-size : 12px;border : 1px solid #cc9933;width : 200px;font-family : arial, sans-serif;}.pstrength-minchar {font-size : 10px;}</style><script src="Scripts/jquery-1.4.1.js" type="text/javascript"></script><script type="text/javascript" src="Scripts/jquery.pstrength-min.1.2.js"></script><script type="text/javascript"> $(function () { $('.password').pstrength(); });</script></head><body> <form id="form1" runat="server">
<table><tr><td valign="top"><strong>密码:</strong></td><td><input class="password" type="password" name="Password" size="20"></td></tr></table>
</form></body></html>jquery.pstrength-min.1.2.js:( function (A) { A.extend(A.fn, { pstrength: function (B) { var B = A.extend({ verdects: ["很弱", "弱", "中等", "好", "很好很强大"], colors: ["#f00", "#c06", "#f60", "#3c0", "#3f0"], scores: [10, 15, 30, 40], common: ["password", "sex", "god", "123456", "123", "liverpool", "letmein", "qwerty", "monkey"], minchar: 6 }, B); return this.each(function () { var C = A(this).attr("id"); A(this).after("<div class=/"pstrength-minchar/" id=/"" + C + "_minchar/">提示: 最少 " + B.minchar + " 位.</div>"); A(this).after("<div class=/"pstrength-info/" id=/"" + C + "_text/"></div>"); A(this).after("<div class=/"pstrength-bar/" id=/"" + C + "_bar/" style=/"border: 1px solid white; font-size: 1px; height: 5px; width: 0px;/"></div>"); A(this).keyup(function () { A.fn.runPassword(A(this).val(), C, B) }) }) }, runPassword: function (D, F, C) { nPerc = A.fn.checkPassword(D, C); var B = "#" + F + "_bar"; var E = "#" + F + "_text"; if (nPerc == -200) { strColor = "#f00"; strText = "不安全的密码!"; A(B).css({ width: "0%" }) } else { if (nPerc < 0 && nPerc > -199) { strColor = "#ccc"; strText = "太短了!"; A(B).css({ width: "5%" }) } else { if (nPerc <= C.scores[0]) { strColor = C.colors[0]; strText = C.verdects[0]; A(B).css({ width: "10%" }) } else { if (nPerc > C.scores[0] && nPerc <= C.scores[1]) { strColor = C.colors[1]; strText = C.verdects[1]; A(B).css({ width: "25%" }) } else { if (nPerc > C.scores[1] && nPerc <= C.scores[2]) { strColor = C.colors[2]; strText = C.verdects[2]; A(B).css({ width: "50%" }) } else { if (nPerc > C.scores[2] && nPerc <= C.scores[3]) { strColor = C.colors[3]; strText = C.verdects[3]; A(B).css({ width: "75%" }) } else { strColor = C.colors[4]; strText = C.verdects[4]; A(B).css({ width: "92%" }) } } } } } } A(B).css({ backgroundColor: strColor }); A(E).html("<span style='color: " + strColor + ";'>" + strText + "</span>") }, checkPassword: function (C, B) { var F = 0; var E = B.verdects[0]; if (C.length < B.minchar) { F = (F - 100) } else { if (C.length >= B.minchar && C.length <= (B.minchar + 2)) { F = (F + 6) } else { if (C.length >= (B.minchar + 3) && C.length <= (B.minchar + 4)) { F = (F + 12) } else { if (C.length >= (B.minchar + 5)) { F = (F + 18) } } } } if (C.match(/[a-z]/)) { F = (F + 1) } if (C.match(/[A-Z]/)) { F = (F + 5) } if (C.match(//d+/)) { F = (F + 5) } if (C.match(/(.*[0-9].*[0-9].*[0-9])/)) { F = (F + 7) } if (C.match(/.[!,@,#,$,%,^,&,*,?,_,~]/)) { F = (F + 5) } if (C.match(/(.*[!,@,#,$,%,^,&,*,?,_,~].*[!,@,#,$,%,^,&,*,?,_,~])/)) { F = (F + 7) } if (C.match(/([a-z].*[A-Z])|([A-Z].*[a-z])/)) { F = (F + 2) } if (C.match(/([a-zA-Z])/) && C.match(/([0-9])/)) { F = (F + 3) } if (C.match(/([a-zA-Z0-9].*[!,@,#,$,%,^,&,*,?,_,~])|([!,@,#,$,%,^,&,*,?,_,~].*[a-zA-Z0-9])/)) { F = (F + 3) } for (var D = 0; D < B.common.length; D++) { if (C.toLowerCase() == B.common[D]) { F = -200 } } return F } }) }) (jQuery)