פופ-אוברים
תיעוד ודוגמאות להוספת חלונות קופצים של Bootstrap, כמו אלה שנמצאים ב-iOS, לכל רכיב באתר שלך.
סקירה כללית
דברים שכדאי לדעת בעת שימוש בתוסף popover:
- Popovers מסתמכים על ספריית הצד השלישי Popper.js לצורך מיקום. עליך לכלול popper.min.js לפני bootstrap.js או להשתמש ב-
bootstrap.bundle.min.js
/bootstrap.bundle.js
שמכיל את Popper.js על מנת ש-popovers יפעלו! - חלונות קופצים דורשים את הפלאגין של תיאור כלי כתלות.
- אם אתה בונה את JavaScript שלנו מהמקור, זה דורש
util.js
. - חלונות קופצים ניתנים להצטרפות מסיבות ביצועים, לכן עליך לאתחל אותם בעצמך .
- אורך אפס
title
וערכיםcontent
לעולם לא יראו פופ-אובר. - ציין
container: 'body'
כדי להימנע מעיבוד בעיות ברכיבים מורכבים יותר (כמו קבוצות הקלט שלנו, קבוצות לחצנים וכו'). - הפעלת popovers על אלמנטים מוסתרים לא תעבוד.
- יש להפעיל פופ-אובר עבור אלמנטים
.disabled
אוdisabled
אלמנטים ברכיב עטיפה. - כאשר מופעלים מעוגנים העוטפים קווים מרובים, הפופ-אוברים יתרכזו בין הרוחב הכללי של העוגנים. השתמש
.text-nowrap
ב-<a>
s שלך כדי להימנע מהתנהגות זו. - יש להסתיר חלונות קופצים לפני שהרכיבים התואמים שלהם יוסרו מה-DOM.
- ניתן להפעיל פופ-אובר הודות לאלמנט בתוך DOM בצל.
אפקט האנימציה של רכיב זה תלוי prefers-reduced-motion
בשאילתת המדיה. עיין בסעיף תנועה מופחתת בתיעוד הנגישות שלנו .
המשך לקרוא כדי לראות כיצד פופ-אובר עובד עם כמה דוגמאות.
דוגמה: אפשר פופ-אובר בכל מקום
דרך אחת לאתחל את כל הפופ-אוברים בדף תהיה לבחור אותם לפי data-toggle
התכונה שלהם:
דוגמה: שימוש container
באפשרות
כאשר יש לך כמה סגנונות ברכיב אב שמפריעים ל-popover, תרצה לציין התאמה אישית container
כך שה-HTML של ה-pover יופיע בתוך הרכיב הזה במקום זאת.
דוגמא
ארבעה כיוונים
ארבע אפשרויות זמינות: מיושרות למעלה, ימינה, למטה ושמאלה.
סגור בלחיצה הבאה
השתמש focus
בטריגר כדי לבטל פופ-אובר בלחיצה הבאה של המשתמש על רכיב אחר מאשר רכיב החלפת המצב.
נדרש סימון ספציפי לביטול בלחיצה הבאה
להתנהגות נכונה בין דפדפנים ופלטפורמות, עליך להשתמש <a>
בתג, לא בתג<button>
, וכן עליך לכלול tabindex
תכונה.
אלמנטים מושבתים
אלמנטים עם disabled
התכונה אינם אינטראקטיביים, כלומר המשתמשים אינם יכולים לרחף או ללחוץ עליהם כדי להפעיל פופ-אובר (או טיפים). כדרך לעקיפת הבעיה, תרצה להפעיל את הפופ-אובר מתוך עטיפה <div>
או <span>
לעקוף את pointer-events
הרכיב המושבת.
עבור מפעילי פופ-אובר מושבתים, ייתכן שתעדיף גם data-trigger="hover"
כך שה-pover יופיע כמשוב ויזואלי מיידי למשתמשים שלך, מכיוון שהם עשויים שלא לצפות ללחוץ על אלמנט מושבת.
נוֹהָג
הפעל חלונות קופצים באמצעות JavaScript:
אפשרויות
ניתן להעביר אפשרויות באמצעות תכונות נתונים או JavaScript. עבור תכונות נתונים, הוסף את שם האפשרות ל- data-
, כמו ב- data-animation=""
.
שים לב שמסיבות אבטחה לא ניתן לספק את האפשרויות sanitize
, sanitizeFn
ו באמצעות תכונות נתונים.whiteList
שֵׁם | סוּג | בְּרִירַת מֶחדָל | תיאור |
---|---|---|---|
אנימציה | בוליאני | נָכוֹן | החל מעבר דהייה של CSS על הפופ-אובר |
מְכוֹלָה | מחרוזת | אלמנט | שֶׁקֶר | שֶׁקֶר | מוסיף את הפופ-אובר לרכיב מסוים. דוגמה: |
תוֹכֶן | מחרוזת | אלמנט | פוּנקצִיָה | '' | ערך ברירת המחדל של תוכן אם אם ניתנת פונקציה, היא תיקרא |
לְעַכֵּב | מספר | לְהִתְנַגֵד | 0 | עיכוב הצגת והסתרת הפופ-אובר (ms) - אינו חל על סוג טריגר ידני אם מסופק מספר, השהיה מוחל גם על הסתרה/הצגה מבנה האובייקט הוא: |
html | בוליאני | שֶׁקֶר | הכנס HTML לתוך הפופ-אובר. אם False, text השיטה של jQuery תשמש להכנסת תוכן ל-DOM. השתמש בטקסט אם אתה מודאג מהתקפות XSS. |
מיקום | מחרוזת | פוּנקצִיָה | 'ימין' | כיצד למקם את הפופ-אובר - אוטומטי | למעלה | תחתון | שמאל | ימין. כאשר משתמשים בפונקציה לקביעת המיקום, היא נקראת עם צומת DOM המוקפץ כארגומנט הראשון שלה והצומת המפעיל DOM כצומת השני שלו. ההקשר |
בוחר | מחרוזת | שֶׁקֶר | שֶׁקֶר | אם מסופק בורר, אובייקטים קופצים יואצלו ליעדים שצוינו. בפועל, זה משמש כדי לאפשר לתוכן HTML דינמי להוסיף חלונות קופצים. ראה זאת ודוגמה אינפורמטיבית . |
תבנית | חוּט | '<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>' |
בסיס HTML לשימוש בעת יצירת הפופ-אובר. הפופ-אובר הפופ-אובר
רכיב העטיפה החיצוני ביותר צריך לכלול את |
כותרת | מחרוזת | אלמנט | פוּנקצִיָה | '' | ערך כותרת ברירת מחדל אם אם ניתנת פונקציה, היא תיקרא |
הדק | חוּט | 'נְקִישָׁה' | כיצד מופעל פופ-אובר - לחץ על | לרחף | מיקוד | מדריך ל. אתה יכול לעבור טריגרים מרובים; להפריד ביניהם עם רווח. manual לא ניתן לשלב עם כל טריגר אחר. |
לְקַזֵז | מספר | חוּט | 0 | קיזוז הפופ-אובר ביחס ליעדו. למידע נוסף עיין במסמכי האופסט של Popper.js . |
מיקום fallback | מחרוזת | מַעֲרָך | 'לְהַעִיף' | אפשר לציין באיזו עמדה פופר ישתמש ב-fallback. למידע נוסף עיין במסמכי ההתנהגות של Popper.js |
גְבוּל | מחרוזת | אֵלֵמֶנט | 'סcrollPrent' | גבול אילוץ הצפת של הפופ-אובר. מקבל את הערכים של 'viewport' , 'window' , 'scrollParent' או הפניה ל-HTMLElement (JavaScript בלבד). למידע נוסף עיין במסמכי preventOverflow של Popper.js . |
לחטא | בוליאני | נָכוֹן | הפעל או השבת את החיטוי. אם יופעל 'template' , 'content' והאפשרויות 'title' יעברו חיטוי. |
רשימה לבנה | לְהִתְנַגֵד | ערך ברירת מחדל | אובייקט המכיל תכונות ותגים מותרים |
sanitizeFn | null | פוּנקצִיָה | ריק | כאן אתה יכול לספק פונקציית חיטוי משלך. זה יכול להיות שימושי אם אתה מעדיף להשתמש בספרייה ייעודית לביצוע חיטוי. |
תכונות נתונים עבור פופ-אובר בודדים
לחלופין ניתן לציין אפשרויות עבור פופ-אובר בודדים באמצעות שימוש בתכונות נתונים, כפי שהוסבר לעיל.
שיטות
שיטות ומעברים אסינכרוניים
כל שיטות ה-API הן אסינכרוניות ומתחילות מעבר . הם חוזרים למתקשר ברגע שהמעבר מתחיל אבל לפני שהוא מסתיים . בנוסף, תתעלם מקריאת שיטה על רכיב מעבר .
$().popover(options)
מאתחל פופ-אובר עבור אוסף אלמנטים.
.popover('show')
חושף פופ-אובר של אלמנט. חוזר אל המתקשר לפני שהפופ-אובר הוצג בפועל (כלומר לפני shown.bs.popover
התרחשות האירוע). זה נחשב להפעלה "ידנית" של הפופ-אובר. חלונות קופצים שהכותרת והתוכן שלהם הם באורך אפס לעולם אינם מוצגים.
.popover('hide')
מסתיר פופ-אובר של אלמנט. חוזר אל המתקשר לפני שהפופ-אובר הוסתר בפועל (כלומר לפני hidden.bs.popover
התרחשות האירוע). זה נחשב להפעלה "ידנית" של הפופ-אובר.
.popover('toggle')
מחליף את הפופ-אובר של רכיב. חוזר אל המתקשר לפני שהפופ-אובר הוצג או הוסתר בפועל (כלומר לפני שהאירוע shown.bs.popover
או hidden.bs.popover
מתרחש). זה נחשב להפעלה "ידנית" של הפופ-אובר.
.popover('dispose')
מסתיר והורס את הפופ-אובר של אלמנט. חלונות קופצים המשתמשים בהאצלה (שנוצרים באמצעות האפשרותselector
) אינם ניתנים להרס בנפרד על רכיבי טריגר צאצאים.
.popover('enable')
נותן לפופ-אובר של אלמנט את היכולת להיות מוצג. חלונות קופצים מופעלים כברירת מחדל.
.popover('disable')
מסיר את היכולת להציג פופ-אובר של רכיב. הפופ-אובר יוכל להיות מוצג רק אם הוא מופעל מחדש.
.popover('toggleEnabled')
מחליף את היכולת להצגה או להסתרה של חלון קופץ של רכיב.
.popover('update')
מעדכן את המיקום של חלון קופץ של רכיב.
אירועים
סוג אירוע | תיאור |
---|---|
show.bs.popover | אירוע זה מופעל מיד כאשר show שיטת המופע נקראת. |
מוצג.bs.popover | אירוע זה מופעל כאשר הפופ-אובר נעשה גלוי למשתמש (יחכה לסיום מעברי CSS). |
hide.bs.popover | אירוע זה מופעל מיד כאשר hide שיטת המופע נקראה. |
hidden.bs.popover | אירוע זה מופעל כאשר הפופ-אובר סיים להיות מוסתר מהמשתמש (יחכה לסיום מעברי CSS). |
inserted.bs.popover | אירוע זה מופעל לאחר show.bs.popover האירוע כאשר תבנית הפופ-אובר נוספה ל-DOM. |