使用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/
最佳答案
您可以使用 straight HTML version :
<form action="demo_form.asp">
Username: <input type="text" name="usrname" maxlength="10"><br>
<input type="submit" value="Submit">
</form>
关于javascript - 防止用户在达到最大长度时输入其他字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21686189/