ASP.NET MVC Ajax. Можно ли выполнить ссылку -GENERATED- Ajax с помощью ввода с клавиатуры?

StackOverflow https://stackoverflow.com/questions/906761

Вопрос

Может ли кто-нибудь выполнить сгенерированный Ajax.ActionLink, когда пользователь нажимает клавишу на клавиатуре? (Это нужно для доступности)

ПРИМЕЧАНИЕ:Я использую библиотеки ASP.NET MVC + Microsoft Js (...Ajax.js/...MvcAjax.js) + jQuery

Javascript для захвата нажатия клавиш (IE + Firefox)

$(document).keypress(function(event) {
    if(event.keyCode == 27) {
        //execution here
        var a = document.getElementById('linkid');
    }
});

HTML, созданный ASP.NET MVC (Аякс.ДействиеСсылка())

<a id="linkid" href="/controller/action" onclick="
Sys.Mvc.AsyncHyperlink.handleClick(this, new Sys.UI.DomEvent(event), 
{ insertionMode: Sys.Mvc.InsertionMode.replace, 
updateTargetId: 'SomeDivId' });
">LinkText</a>

Следующее — это не то, что я ищу, это не работает!

$(document).keypress(function(event) {
    if(event.keyCode == 27) {
        var a = document.getElementById('linkid');
        a.onclick();           //doesn't exist in Firefox
        a.click();             //doesn't "work" in Firefox (reference to "this" [a] is needed .NET MVC javascript)
        a["onclick"]();        //same as .onclick()
        a["click"]();          //same as .click()

        //or even:
        a.onclick.apply(a);    //doesn't exist in Firefox
        a.click.apply(a);      //Somehow keeps "this" reference, but throws Sys.ArgumentUndefinedException
    }
});    
Это было полезно?

Решение

Пробовали ли вы использовать триггерный механизм jQuery?

$(document).keypress( function(e) {
    if (e.keyCode == 27) {
       $(this).trigger('click');
    }
}

В противном случае вы можете просто вызвать href, который выполнит полную обратную передачу, но должен выполнить желаемое действие, если действие написано для обработки как AJAX-запросов, так и не-AJAX-запросов.

$(document).keypress( function(e) {
    if (e.keyCode == 27) {
       location.href = $(this).attr('href');
    }
}

Другие советы

Пожалуйста, попробуйте это:

            var a = document.getElementById('linkid');
        $(a).trigger('click');
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top