JQuery.focus() и .blur() не работают в Chrome или Safari
Я создаю форму опроса, в которой должен быть задан каждый вопрос и набор ответов (путем изменения цвета фона), когда пользователь фокусируется на них..focus() и .blur() работают как в Firefox, так и в IE, но не полностью в Safari и Chrome. Я также пробовал .focusin() и .focusout() с теми же результатами. EDIT: нажатие не запускает событие фокуса, но табуляция через поля ввода делает. Я говорю не полностью, потому что он работает для ввода текста, выбирает входные и текстовые входы; но не радио и флажки.
$(document).ready(function()
{
$("form li").focusin(function()
{
$(this).addClass("over");
}).focusout(function()
{
$(this).removeClass("over");
});
});
Это применяется к блокам html, подобным этому:
<li>
<label for="webmail" class="desc">Email</label>
<input type="text" name="webmail" id="webmail" />
</li>
<li>
<label for="business" class="desc">Purpose of your Charter Flight:</label>
<div>
<span>
<input type="radio" name="purpose" id="business" class="radio" />
<label class="choice" for="business">Business</label>
</span>
<span>
<input type="radio" name="purpose" id="pleasure" class="radio" />
<label class="choice" for="pleasure">Pleasure</label>
</span>
</div>
</li>
Я пытался возиться с переключателями, но я ищу более элегантное решение, которое не предполагает использование запутанной логики, чтобы заставить ее работать. Любые идеи?
Ответы
Ответ 1
Я думал об этом на машине домой прошлой ночью и понял это сам по себе, это может быть не самое элегантное решение, но оно, безусловно, работает.
$(document).ready(function()
{
$("textarea, input, select, .radio, .checkbox").click(function()
{
$("form li.over").toggleClass("over");
$(this).parents("li").toggleClass("over");
});
});
Спасибо в любом случае!
Ответ 2
Я тоже наткнулся на эту проблему давно, и, как ни странно, это была радио-кнопка, которая давала мне горе.
Попробуйте использовать jQuery.change()
, вот рабочий пример из этой проблемы, у меня был
$("input#zendesk-dropbox-askedbefore, input#zendesk-dropbox-newhere").change(function() {
$("label#zendesk-dropbox-label-askedbefore, label#zendesk-dropbox-label-newhere").toggleClass('zendesk-dropbox-label-highlight');
});
Если это неясно из-за моего безумного использования имен идентификаторов, input#zendesk-dropbox-askedbefore
и input#zendesk-dropbox-newhere
- оба переключателя.
Ответ 3
// In js area write following method
$('#chkRikin').focus(function() {
alert('Say Hi Rikin');
});
// in html area write following code anenter code hered test it your self
<input type="checkbox" onclick="this.focus()" onblur="yourMethod()" />
it works in google crom