5

ブートストラップの先行入力を使用しています。

動作するかどうかは、次の jQuery コードに依存します。

el.on('keyup', doSomething() )

Windows 上の Chrome では正常に動作します。Android の Chrome ではそうではありません。keyup イベントが発生することはありません。それがバインドされている要素には、間違いなくフォーカスがあります。

これは最近の開発のようです。

Chrome 28.0.1500.64 Android 4.1.2 SGP321 ビルド/10.1.1.A.1.307

ありがとう

――ジャスティン・ワイリー

4

2 に答える 2

3

今日、この同じ問題に遭遇しました。android chrome がこれらの主要なイベントをサポートしないのはどうしてですか! ここまでで回避策を見つけたと思いますが、今のところ私が思いついた修正を次に示します。

function newKeyUpDown(originalFunction, eventType) {
    return function() {
        if ("ontouchstart" in document.documentElement) { // if it's a touch device, or test here specifically for android chrome
            var $element = $(this), $input = null;
            if (/input/i.test($element.prop('tagName')))
                $input = $element;
            else if ($('input', $element).size() > 0)
                $input = $($('input', $element).get(0));

            if ($input) {
                var currentVal = $input.val(), checkInterval = null;
                $input.focus(function(e) {
                    clearInterval(checkInterval);
                    checkInterval = setInterval(function() {
                        if ($input.val() != currentVal) {
                            var event = jQuery.Event(eventType);
                            currentVal = $input.val();
                            event.which = event.keyCode = (currentVal && currentVal.length > 0) ? currentVal.charCodeAt(currentVal.length - 1) : '';
                            $input.trigger(event);
                        }
                    }, 30);
                });
                $input.blur(function() {
                    clearInterval(checkInterval);
                });
            }
        }
        return originalFunction.apply(this, arguments);
    }
}
$.fn.keyup = newKeyUpDown($.fn.keyup, 'keyup');
$.fn.keydown = newKeyUpDown($.fn.keydown, 'keydown');
于 2013-12-11T01:16:51.807 に答える