开发者

What is the best way to limit text input entry to numbers, lowercase letters, and certain symbols?

开发者 https://www.devze.com 2022-12-24 05:45 出处:网络
Without using jQuery, what is the best way to limit text entry of a textbox to numbers, lowercase letters and a given set of symbols (for example -开发者_运维技巧 and _)? If the user enters an upperca

Without using jQuery, what is the best way to limit text entry of a textbox to numbers, lowercase letters and a given set of symbols (for example -开发者_运维技巧 and _)? If the user enters an uppercase letter, I would like it to be automatically converted to a lowercase letter, and if the user enters a symbol not within the given set, I would like to be able to instantly show a validation error (show some element adjacent to or below the text box).

What's the cleanest cross-browser way of doing this without the aid of jQuery?


Attach the following to your elements onkeyup event.

function onkeyup() 
{
    var el = document.getElementById("id"); // or however you want to get it

    el.value = el.value.toLowerCase(); // covert to lower case

    if (el.value.match(/[^-\d\w]/)) // check for illegal characters
    {
        // show validation error
        ...
        // remove invalid characters
        el.value = el.value.replace(/[^-\d\w]/g, "");
    }
    else
    {
        // hide validation error
    }
}

The regex matches any character which is not a digit, a letter, a hyphen or an underscore.

0

精彩评论

暂无评论...
验证码 换一张
取 消