Присоединение событий клавиатуры к элементу SVG внутри HTML - PullRequest
7 голосов
/ 19 июля 2011

Есть ли способ прикрепить событие textInput или нажатия клавиши (или вообще любого другого ввода текста) к элементу SVG при запуске SVG внутри HTML в браузере?

Я могу прикрепить обработчик событий к document.documentElement, но ничего не происходит, когда я присоединяю обработчик событий с помощью какого-либо механизма к SVGElement anykind ... svg, g, rect ...

Я вижу из спецификации SVG, что это не поддерживается ( W3 SVG список событий ), но поддерживают ли какие-либо браузеры какие-либо дополнительные функции?

Я не могу заставить следующее работать с Chrome или firefox ...

        <!DOCTYPE HTML>
<html>
<head>
<title>Key event test</title>
<style type="text/css">
body,html {
    margin: 0;
    padding: 0;
    height: 100%;
    width: 100%;
    background: #f00;
}

#main {
    margin: 0;
    padding: 0;
    height: 100%;
    width: 80%;
    background: #0f0;
    float: right;
}

#drawArea {
    margin: 0;
    padding: 0;
    height: 100%;
    width: 100%;
    background: #ffffff;
}

#side {
    margin: 0;
    padding: 0;
    height: 100%;
    width: 20%;
    background: #00f;
    float: left;
}


</style>
<script type="text/javascript">

    function createBoundEventHandler(el, name) {
        var f = 
            function eventHandler(ev) {
    if("mousedown" === ev.type) {
        el.focus();
    }
    else {
        alert("asEventHandler: " + el.localName + " " + name + " " + ev.type);
    }
    return true;
            };
        return f;
    }

    function doEvent(event, elementName, eventName) {
        alert("asAttribute: " + elementName + " " + eventName + " " + event.type);
        return true;
    }

    function addEventHandler(element, eventName, type) {
        var attrName = "on" + eventName;
        var attrValue = "doEvent(evt, '" + element.localName + "', '" + eventName + "')";
        if("asAttribute" === type) {
            element.setAttribute( attrName, attrValue);
        }
        else {
            element.addEventListener(eventName, createBoundEventHandler(element, eventName), false);
        }
    }

    window.onload = function() { 
        var eventHandlerType = "asEventHandler"; //asAttribute asEventHandler

        var svgTarget = document.getElementById('drawArea');
        var svgRect = document.getElementById('aRect');
        var nonSVG = document.getElementById('side');

        addEventHandler(svgTarget, "keypress", eventHandlerType);
        addEventHandler(svgTarget, "mousedown", eventHandlerType);
        addEventHandler(svgTarget, "keyup", eventHandlerType);
        addEventHandler(svgTarget, "keydown", eventHandlerType);

        addEventHandler(svgRect, "keypress", eventHandlerType);
        addEventHandler(svgRect, "mousedown", eventHandlerType);
        addEventHandler(svgRect, "keyup", eventHandlerType);
        addEventHandler(svgRect, "keydown", eventHandlerType);

        addEventHandler(nonSVG, "keypress", eventHandlerType);
        addEventHandler(nonSVG, "mousedown", eventHandlerType);
        addEventHandler(nonSVG, "keyup", eventHandlerType);
        addEventHandler(nonSVG, "keydown", eventHandlerType);

        //We can get a keypress if we attach an event handler to the underlying document Element    
        addEventHandler(document.documentElement, "keypress", eventHandlerType);
    }
</script>
</head>
<body>
    <div id="side" tabindex="0">
    </div>
<div id="main">
    <svg  version="1.1" xmlns="http://www.w3.org/2000/svg" id="drawArea" focusable="true" tabindex="0"> 
    <rect x="0" y="0" width="100" height="100"
            style="fill:yellow; ;stroke-width:2; stroke:rgb(0,0,0)" id="aRect" focusable="true"/>
    </svg>
</div>
</body>
</html>

Как показывает пример, я все еще могу откатиться на ключевые события в элементе документа 'background'. Есть ли у кого-нибудь библиотеки для домашних животных, методики для связи этого с SVGElement.

N.B. Я также пробовал tabindex (0) и фокусировался безрезультатно ...

Спасибо ...

Ответы [ 4 ]

3 голосов
/ 19 июля 2011

Простой ответ может состоять в том, что атрибут 'focusable' не поддерживается в этих браузерах.Чтобы слушатели ключевых событий, например, <rect> имели какой-либо смысл, в svg должна быть концепция фокуса.

2 голосов
/ 08 марта 2016

Как предложил пользователь Erik Dahlström, вам (сначала) нужно добавить слушатель событий для фокуса.

svgRect.addEventListener('focus', function(){
    this.addEventListener('keypress',function(e){
        console.log(e.keyCode);
    });
}, svgRect);
0 голосов
/ 09 сентября 2016

Код Тудорми работает нормально, но будьте осторожны с memmoryleaks, потому что каждый раз, когда вы фокусируете svgRect, новое событие нажатия клавиши будет зарегистрировано на этом элементе.

0 голосов
/ 19 июля 2011

Выезд Raphael.js .Кроме того, я имел большой успех, используя MooTools .Я уверен, что вы, возможно, могли бы добавить некоторые обработчики событий в любой JavaScript-фреймворк, если вы не хотите создавать свои собственные.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...