Je suis en mesure de faire un spectacle div caché/cacher quand un champ d'entrée est mise au point/flou en utilisant le code suivant:jQuery: Sur le focus d'entrée de formulaire, affiche div. cacher div sur le flou (avec une mise en garde)
$('#example').focus(function() {
$('div.example').css('display','block');
}).blur(function() {
$('div.example').fadeOut('medium');
});
Le problème est que je veux div.example
à continuer à être visible lorsque l'utilisateur interagit au sein de ce div. Par exemple. cliquez sur ou surligner le texte etc. dans div.example
. Cependant, div.example
disparaît lorsque l'entrée n'est pas active et que la souris interagit avec les éléments de la div.
Le code html pour les éléments d'entrée et div est comme suit:
<p>
<label for="example">Text:</label>
<input id="example" name="example" type="text" maxlength="100" />
<div class="example">Some text...<br /><br />More text...</div>
</p>
Comment puis-je faire de sorte que le div.example
disparaît uniquement lorsque l'utilisateur clique en dehors de l'entrée et/ou div.example
? J'ai essayé d'expérimenter avec focusin/focusout pour vérifier l'accent sur <p>
mais cela n'a pas fonctionné non plus.
Est-il important que div.example
soit positionné directement sous le champ #exemple en utilisant jQuery? Le code qui fait cela est la suivante:
var fieldExample = $('#example');
$('div.example').css("position","absolute");
$('div.example').css("left", fieldExample.offset().left);
$('div.example').css("top", fieldExample.offset().top + fieldExample.outerHeight());
Mes excuses si cela a été demandé avant, mais les nombreuses questions div show/hide que je lis ne couvre pas. Merci pour vos conseils. :)
Salut Peter, malheureusement, le div disparaît encore. Lorsque vous cliquez ou sélectionnez le texte dans ce div.example, je veux qu'il reste visible. Jusqu'à ce que l'utilisateur clique spécifiquement ailleurs, le div devrait disparaître. Appréciez votre aide ici. Merci :) – Lyon
@Lyon vous avez raison. Juste mis à jour ma réponse avec un moyen qui devrait fonctionner pour vous. – PetersenDidIt
Merci Peter. J'apprécie vraiment votre aide à ce sujet. J'ai creusé mes cerveaux en essayant de comprendre comment faire ça. Est-ce que cela pourrait également être fait de sorte que lorsque l'utilisateur clique ailleurs, comme du texte sur la page, ou l'arrière-plan de la page, (par exemple entrée/div n'est plus au point), ce div.example disparaîtra aussi? Actuellement, il ne disparaît que lorsque je clique sur l'entrée suivante. Merci beaucoup. J'essaie d'adapter votre code pour le faire en vain :( – Lyon