阻止用户在达到最大长度时输入其他字符

时间:2014-02-10 19:30:04

标签: javascript forms angularjs validation input

使用angularjs,我对ng-maxlength标签不满意。我希望输入字段阻止用户在达到最大长度时输入其他字符。因此,我尝试编写一个指令来验证keydown / keypress上的输入,而不是ng-maxlength

.directive('vldMaxLength', function() {
  return function (scope, element, attr) {
    element.bind('keydown keypress', function (event) {
      if(event.target.value.length >= 10 && (event.which !== 8 && event.which !== 46)) {
        event.preventDefault();
      }
    });
  };
})

这很有效,但是用户无法突出显示字符串的一部分并用不同的字符替换。也许我可以添加到指令中以允许这个?或者可能有一种更简单的方法来获得此功能而不是使用指令。

JSFiddle:http://jsfiddle.net/DwKZh/147/

1 个答案:

答案 0 :(得分:15)

您可以使用straight HTML version

<form action="demo_form.asp">
  Username: <input type="text" name="usrname" maxlength="10"><br>
  <input type="submit" value="Submit">
</form>