У меня есть следующий код :
HTML:
<input type='text' class='a' />
<div class='inst' tag='a'></div>
<input type='text' class='b' />
<div class='inst' tag='b'></div>
<input type='text' class='c' />
<div class='inst' tag='c'></div>
JS:
$(function() {
$('.inst').click(function() {
alert($(this).attr('tag') + ' clicked');
});
$('[type=text]').focus(function() {
show_inst($(this).attr('class'));
}).blur(function() {
//hide_inst($(this).attr('class'));
});
function show_inst(tag) {
$('div.inst[tag=' + tag + ']').html(tag + ' instructions');
}
function hide_inst(tag) {
$('div.inst[tag=' + tag + ']').html('');
}
});
CSS:
.inst {
width: 200px;
height: 100px;
border: 1px solid black;
margin: 10px;
cursor: pointer;
}
Работает нормально: при нажатии inst
появляется сообщение с предупреждением, и когда ввод становится сфокусированным, появляется инструкция.
Теперь я хочу, чтобы не соответствующие инструкции исчезали при размытии. Поэтому я попытался добавить закомментированную строку внутри blur()
. Это не работает так, потому что blur()
вызывается первым и удаляет инструкцию, поэтому, если я нажимаю на инструкцию - ничего не происходит.
Как я мог решить это?