Javascript String.fromCharCode 返回错误值

标签 javascript knockout.js

我有这个 Knockout 自定义绑定(bind)来验证文本框是否只包含英文字母。但是,Javascript 的 String.fromCharCode 似乎返回了错误的值。

例如,希伯来字母 “ש” 返回为英文字母“A”,右侧数字键盘中的数字“1”返回为“a”...

这是我的 Knockout 绑定(bind):

var arrValidKeys = [8, 16, 17, 20, 35, 36, 37, 39, 46];
    ko.bindingHandlers.validateText = {
        init: function (element, valueAccessor) {
            $(element).on("keydown", function (event) {

                //Regex pattern: allow only (A to Z uppercase, a to z lowercase)
                var englishAlphabet = /[A-Za-z]/g;

                // Retrieving the key from the char code passed in event.which
                var key = String.fromCharCode(event.which);

                // keyCodes list: http://stackoverflow.com/a/3781360/114029
                // check that the key is valid with the above Regex
                valueAccessor()($(this).val());

                return ((jQuery.inArray(event.keyCode, arrValidKeys) != -1) || englishAlphabet.test(key));
            });

            $(element).on("keyup", function (event) {

                //Regex pattern: allow only (A to Z uppercase, a to z lowercase)
                var englishAlphabet = /[A-Za-z]/g;

                // Retrieving the key from the char code passed in event.which
                var key = String.fromCharCode(event.which);

                // keyCodes list: http://stackoverflow.com/a/3781360/114029
                // check that the key is valid with the above Regex

                valueAccessor()($(this).val());

                return ((jQuery.inArray(event.keyCode, arrValidKeys) != -1) || englishAlphabet.test(key));
            });

            $(element).on("paste", function (e) {
                var englishAlphabet = /[A-Za-z]/g;
                if (englishAlphabet.test($(this).val()))
                    valueAccessor()($(this).val());
                else
                    e.preventDefault();
            });
        }
    };

最佳答案

遵循@Jeanluca Scaljeri 从这篇文章中提出的建议:Get Correct keyCode for keypad(numpad) keys

我将我的代码更新为:

// keyCodes list: https://stackoverflow.com/a/3781360/114029
var arrValidKeys = [8, /*backspace*/
                    16, /*shift*/
                    17, /*ctrl*/
                    20, /*caps lock*/
                    35, /*end*/
                    36, /*home*/
                    37, /*left arrow*/
                    39, /*right arrow*/
                    46, /*delete*/];

function validateChar(keyCode) {
    //Regex pattern: allow only (A to Z uppercase, a to z lowercase)
    var englishAlphabet = /[A-Za-z]/g;

    //Retrieving the key from the char code passed in event.which
    var key = String.fromCharCode(keyCode);

    //Check that the key is valid with the above Regex
    return ((jQuery.inArray(keyCode, arrValidKeys) != -1) ||     englishAlphabet.test(key));
}

ko.bindingHandlers.validateText = {
    init: function (element, valueAccessor) {
        $(element).on("keypress", function (event) {
            valueAccessor()($(this).val());
            return validateChar(event.which);
        });

        $(element).on("keydown", function (event) {
            valueAccessor()($(this).val());
            return validateChar(event.which);
        });

        $(element).on("keyup", function (event) {
            valueAccessor()($(this).val());
            return validateChar(event.which);
        });

        $(element).on("paste", function (e) {
            var englishAlphabet = /^[A-Za-z]+$/g;
            var text = e.originalEvent.clipboardData.getData('Text');
            if (!englishAlphabet.test(text))
                e.preventDefault();
        });
    }
};

我添加所有 3 个事件(keypresskeydownkeyup)的原因是 keypress单独按下退格键时不会触发,我需要它来更新带有可观察到的 knockout 的标签。

这是一个有效的 jsfiddle 链接:https://jsfiddle.net/2ma9nhn7/6/

关于Javascript String.fromCharCode 返回错误值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30161605/

相关文章:

javascript - 无法让我与嵌套 viewModel 的绑定(bind)来使用对象而不是字符串

html - 我想一次只显示列表中的 2 个名字,然后单击下一个按钮,出现 2 个名字,但有一个错误

jquery - 在jQuery中调用knockout viewmodel函数

javascript - 使用 TinyMCE 和 Symfony3 实现 FileMangerBundle (artgris)

javascript - Knockout JS - viewModel 访问

javascript - Slick.js - 自动播放时多个轮播不同步

javascript - 如何在 React.js 中预加载图像?

jquery - KnockoutJS 内存释放

javascript - 关闭网络套接字不会在服务器上引起事件

javascript - 切换jquery后如何留在div上?