javascript - ejemplo - onblur html5
blur event.relatedTarget devuelve null (1)
Respuesta corta: agregue el tabindex="0"
a un elemento que debería aparecer en event.relatedTarget
.
Explicación: event.relatedTarget
contiene un elemento que ganó el foco. Y el problema es que su división específica no puede obtener un enfoque porque el navegador piensa que este elemento no es un botón / campo o algún tipo de elemento de control.
Aquí están los elementos que pueden ganar enfoque por defecto:
<a>
elementos con atributohref
especificado- Elementos
<link>
con el atributohref
especificado<button>
elementos- Elementos
<input>
que no estánhidden
<select>
elementos- elementos
<textarea>
<menuitem>
elementos- elementos con atributo
draggable
- Elementos de
<audio>
y<video>
con atributos decontrols
especificados
Por event.relatedTarget
tanto, event.relatedTarget
contendrá los elementos anteriores cuando suceda onblur
. Todos los demás elementos no se contabilizarán y al hacer clic en ellos se pondrá null
en event.relatedTarget
.
Pero es posible cambiar este comportamiento. Puede ''marcar'' el elemento DOM como elemento que puede enfocar con el atributo tabindex . Esto es lo que dice standart:
El
tabindex
contenido detabindex
permite a los autores indicar que se supone que un elemento se puede enfocar, si se debe poder acceder mediante la navegación de enfoque secuencial y, opcionalmente, sugerir dónde aparece el elemento en el orden de navegación de enfoque secuencial.
Así que aquí está el fragmento de código corregido:
function lose_focus(event) {
if(event.relatedTarget === null) {
document.getElementById(''text-field'').value = '''';
}
}
.special {
width: 200px;
height: 100px;
background: #ccc;
border: 1px solid #000;
margin: 25px 0;
padding: 15px;
}
.special:hover {
cursor: pointer;
}
<input id="text-field" type="text" onblur="lose_focus(event)" placeholder="Type something...">
<div tabindex="0" class="special">Clicking here should not cause clearing!</div>
Tengo un campo <input type="text">
y necesito borrarlo cuando este campo pierde el foco (lo que significa que el usuario hizo clic en algún lugar de la página). Pero hay una excepción. El campo de texto de entrada no se debe borrar cuando el usuario hace clic en un elemento específico.
Intenté usar event.relatedTarget
para detectar si el usuario hizo clic no solo en alguna parte, sino en mi <div>
específico.
Sin embargo, como puede ver en el siguiente fragmento de código, simplemente no funciona. event.relatedTarget
siempre vuelve null
!
function lose_focus(event) {
if(event.relatedTarget === null) {
document.getElementById(''text-field'').value = '''';
}
}
.special {
width: 200px;
height: 100px;
background: #ccc;
border: 1px solid #000;
margin: 25px 0;
padding: 15px;
}
.special:hover {
cursor: pointer;
}
<input id="text-field" type="text" onblur="lose_focus(event)" placeholder="Type something...">
<div class="special">Clicking here should not cause clearing!</div>