خلاصه
<howto-tooltip>
یک پنجره بازشو است که اطلاعات مربوط به یک عنصر را هنگامی که عنصر فوکوس صفحه کلید را دریافت می کند یا ماوس روی آن قرار می گیرد، نمایش می دهد. عنصری که راهنمای tooltip را فعال می کند به عنصر tooltip با aria-describedby
ارجاع می دهد.
این عنصر به طور خودکار tooltip
نقش را اعمال می کند و tabindex
روی -1 تنظیم می کند، زیرا خود راهنمای ابزار هرگز نمی تواند متمرکز شود.
مرجع
نسخه ی نمایشی
مثال استفاده
<div class="text">
<label for="name">Your name:</label>
<input id="name" aria-describedby="tp1"/>
<howto-tooltip id="tp1">Ideally your name is Batman</howto-tooltip>
<br>
<label for="cheese">Favourite type of cheese: </label>
<input id="cheese" aria-describedby="tp2"/>
<howto-tooltip id="tp2">Help I am trapped inside a tooltip message</howto-tooltip>
کد
class HowtoTooltip extends HTMLElement {
سازنده کارهایی را انجام می دهد که باید دقیقاً یک بار اجرا شوند.
constructor() {
super();
این توابع در بسیاری از مکانها استفاده میشوند، و همیشه باید این مرجع را به درستی متصل کنید، بنابراین یک بار این کار را انجام دهید.
this._show = this._show.bind(this);
this._hide = this._hide.bind(this);
}
connectedCallback()
زمانی فعال می شود که عنصر در DOM درج شود. این مکان مناسبی برای تنظیم نقش اولیه، tabindex، وضعیت داخلی و نصب شنوندگان رویداد است.
connectedCallback() {
if (!this.hasAttribute('role'))
this.setAttribute('role', 'tooltip');
if (!this.hasAttribute('tabindex'))
this.setAttribute('tabindex', -1);
this._hide();
عنصری که راهنمای tooltip را فعال می کند به عنصر tooltip با aria-describedby
ارجاع می دهد.
this._target = document.querySelector('[aria-describedby=' + this.id + ']');
if (!this._target)
return;
راهنمای ابزار باید به فوکوس/محو کردن رویدادها از هدف گوش دهد و همچنین رویدادها را روی هدف قرار دهد.
this._target.addEventListener('focus', this._show);
this._target.addEventListener('blur', this._hide);
this._target.addEventListener('mouseenter', this._show);
this._target.addEventListener('mouseleave', this._hide);
}
disconnectedCallback()
شنوندگان رویداد را که در connectedCallback()
تنظیم شده بودند لغو ثبت می کند.
disconnectedCallback() {
if (!this._target)
return;
شنوندههای موجود را حذف کنید تا حتی با وجود اینکه هیچ راهنمایی ابزاری برای نمایش وجود ندارد، فعال نشوند.
this._target.removeEventListener('focus', this._show);
this._target.removeEventListener('blur', this._hide);
this._target.removeEventListener('mouseenter', this._show);
this._target.removeEventListener('mouseleave', this._hide);
this._target = null;
}
_show() {
this.hidden = false;
}
_hide() {
this.hidden = true;
}
}
customElements.define('howto-tooltip', HowtoTooltip);