The focusin event fires when an element has received focus, after the focus event. The two events differ in that focusin bubbles, while focus does not.
The opposite of focusin is the focusout event, which fires when the element has lost focus.
The focusin event is not cancelable.
Use the event name in methods like addEventListener().
addEventListener("focusin", (event) => {});
This interface also inherits properties from its parent UIEvent, and indirectly from Event.
FocusEvent.relatedTarget -
The element losing focus, if any.
HTML
<form id="form">
<label>
Some text:
<input type="text" placeholder="text input" />
</label>
<label>
Password:
<input type="password" placeholder="password" />
</label>
</form>
JavaScript
const form = document.getElementById("form");
form.addEventListener("focusin", (event) => {
event.target.style.background = "pink";
});
form.addEventListener("focusout", (event) => {
event.target.style.background = "";
});
Result
Note: The UI Events specification describes an order of focus events that's different from what current browsers implement.