CSS Popover APIã®åãè§£æŸãããã€ãã£ããªã¢ãŒãã«é 眮ãå®çŸããŸãããããã®å æ¬çãªã¬ã€ãã§ã¯ãAPIã®æ©èœãå©ç¹ããããŠå®è·µçãªäŸãçšããå®è£ æ¹æ³ã解説ããŸãã
CSS Popover APIïŒãã€ãã£ãã¢ãŒãã«ã®é 眮ã培åºè§£èª¬
CSS Popover APIã¯ãŠã§ããã©ãããã©ãŒã ã«æ¯èŒçæ°ãã远å ãããæ©èœã§ãã¢ãŒãã«ãå«ãããããªãŒããŒãHTMLãšCSSã§çŽæ¥äœæã»ç®¡çããããã®æšæºåãããæ¹æ³ãæäŸããŸããããã«ãããè€éãªJavaScriptãœãªã¥ãŒã·ã§ã³ãäžèŠã«ãªããã¢ã¯ã»ã·ããªãã£ãåäžããŸãããã®èšäºã§ã¯ãPopover APIãæ·±ãæãäžããç¹ã«ã¢ãŒãã«ã®é 眮æ©èœã«çŠç¹ãåœãŠãå®è·µçãªäŸã亀ããŠè§£èª¬ããŸãã
CSS Popover APIãšã¯äœãïŒ
Popover APIã¯ãéçºè ãJavaScriptã«å€§ããäŸåããããšãªããã¢ã¯ã»ã·ãã«ã§æšæºåãããããããªãŒããŒãäœæã§ããããã«ããããã®äžé£ã®å±æ§ãšCSSããããã£ãæäŸããŸããããŒã«ããããããããããŠã³ã¡ãã¥ãŒãã»ã¬ã¯ãããã¯ã¹ããããŠæãéèŠãªã¢ãŒãã«ãšãã£ãäžè¬çãªUIèŠçŽ ã®æ§ç¯ããã»ã¹ãç°¡çŽ åããããšãç®çãšããŠããŸãã
Popover APIã®äž»ãªæ©èœã¯æ¬¡ã®ãšããã§ãïŒ
- ãã€ãã£ããªã¢ã¯ã»ã·ããªãã£ïŒ ããããªãŒããŒã¯ã¹ã¯ãªãŒã³ãªãŒããŒãããŒããŒããŠãŒã¶ãŒã«å¯ŸããŠèªåçã«ã¢ã¯ã»ã·ãã«ã«ãªããŸãã
- ç°¡çŽ åãããããŒã¯ã¢ããïŒ
popover
ãpopovertarget
ã®ãããªHTML屿§ã䜿çšããããšã§ãæå°éã®ã³ãŒãã§ããããªãŒããŒãäœæã§ããŸãã - CSSã«ããã¹ã¿ã€ãªã³ã°ïŒ ããããªãŒããŒã¯æšæºçãªCSSããããã£ã䜿çšããŠã¹ã¿ã€ãªã³ã°ã§ãããã®å€èгãå®å šã«å¶åŸ¡ã§ããŸãã
- èªå管çïŒ APIã衚瀺/é衚瀺ã®ããžãã¯ããã©ãŒã«ã¹ãã©ãããèæ¯ã¯ãªãã¯ã«ããé衚瀺åŠçãæ±ããŸãã
ã¢ãŒãã«é 眮ã®çè§£
ã¢ãŒãã«ã¯ãéèŠãªæ å ±ã衚瀺ãããããŠãŒã¶ãŒã®ã€ã³ã¿ã©ã¯ã·ã§ã³ãä¿ãããããããã®éèŠãªUIèŠçŽ ã§ãããŠãŒã¶ããªãã£ãšèŠèŠçãªé åã®ããã«ã¯ãé©åãªé 眮ãäžå¯æ¬ ã§ããPopover APIã¯ãã¢ãŒãã«ã®é 眮ãå¶åŸ¡ããããã®ããã€ãã®ãªãã·ã§ã³ãæäŸããŸãã
ããã©ã«ãã®é 眮
ããã©ã«ãã§ã¯ãPopover APIã¯ã¢ãŒãã«ããã¥ãŒããŒãã®äžå€®ã«é 眮ããŸããããã¯åççãªåºçºç¹ã§ãããå€ãã®å Žåãé 眮ããã现ããå¶åŸ¡ããããšæãã§ãããããã®ããã©ã«ãã®åäœã¯ãããŸããŸãªãã©ãŠã¶ããã©ãããã©ãŒã ã§äžè²«ããŠãããäžçäžã®ãŠãŒã¶ãŒã«å¯ŸããŠåºæ¬çãªãŠãŒã¶ããªãã£ãä¿èšŒããŸããå€ãã®æååã§ã¯ãéèŠãªæ å ±ãäžå€®ã«é 眮ããããšã¯ãåããªãæç€ºããæ¹æ³ãšãããŠããŸããããããæåã«ãã£ãŠUXãããŒã«å¯ŸããæåŸ ã¯ç°ãªãããããããã®æåŸ ãåæ ããŠé 眮ã調æŽãããå Žåãããã§ããããäŸãã°ãäžéšã®å³ããå·Šãžèšè¿°ããïŒRTLïŒèšèªã§ã¯ãå·Šããå³ãžèšè¿°ããïŒLTRïŒèšèªãšã¯å€§ããç°ãªãUXãæã£ãŠããŸãã
CSSã«ããé 眮ã®ã«ã¹ã¿ãã€ãº
Popover APIã§ã¯ãæšæºçãªCSSããããã£ã䜿çšããŠã¢ãŒãã«ã®äœçœ®ãã«ã¹ã¿ãã€ãºã§ããŸãã以äžã«ãã®é 眮å¶åŸ¡æ¹æ³ã瀺ããŸãïŒ
position: fixed;
ã®äœ¿çš
position: fixed;
ãèšå®ãããšãã¢ãŒãã«ããã¥ãŒããŒãã«å¯ŸããŠé
眮ã§ããŸãããã®åŸãtop
ãright
ãbottom
ãleft
ããããã£ã䜿çšããŠããã®äœçœ®ãæ£ç¢ºã«å¶åŸ¡ã§ããŸãã
[popover] {
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
/* Other styling */
}
ãã®äŸã§ã¯ãã¢ãŒãã«ããã¥ãŒããŒãã®æ£ç¢ºãªäžå€®ã«é
眮ããŸããtransform: translate(-50%, -50%);
ã䜿çšããããšã§ãã¢ãŒãã«ã®ãµã€ãºã«é¢ä¿ãªãäžå€®æããä¿èšŒãããŸãã
FlexboxãšGridã®æŽ»çš
FlexboxãGridã¬ã€ã¢ãŠãã䜿çšããŠãããæŽç·Žãããã¢ãŒãã«é 眮ãäœæã§ããŸããäŸãã°ãFlexboxã䜿ãã°ãã¢ãŒãã«ãæ°Žå¹³ã»åçŽæ¹åã®äž¡æ¹ã§ç°¡åã«äžå€®æãã«ããããšãã§ããŸãã
[popover] {
display: flex;
justify-content: center;
align-items: center;
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.5); /* Optional backdrop */
}
[popover]::backdrop {
background-color: rgba(0, 0, 0, 0.5); /* For wider browser support */
}
[popover] > div {
/* Style the actual modal content */
background-color: white;
padding: 20px;
border-radius: 5px;
}
ãã®äŸã§ã¯ã[popover]
èŠçŽ ãã³ã³ãããšããŠæ©èœããFlexboxã䜿çšããŠãã®åèŠçŽ ïŒã¢ãŒãã«ã®ã³ã³ãã³ãïŒãäžå€®ã«é
眮ããŸãã::backdrop
ç䌌èŠçŽ ã¯ãã¢ãŒãã«ã®èåŸã«åéæã®èæ¯ã远å ããŸãã
JavaScriptã«ããåçãªé 眮ïŒãšèæ ®äºé ïŒ
Popover APIã¯JavaScriptãžã®äŸåãæžããããšãç®çãšããŠããŸããããŠãŒã¶ãŒã®ã€ã³ã¿ã©ã¯ã·ã§ã³ãç»é¢ãµã€ãºã«åºã¥ããŠåçã«é 眮ãè¡ãããã«ã¯ãäŸç¶ãšããŠJavaScriptãå¿ èŠã«ãªãå ŽåããããŸããäŸãã°ãã¢ãŒãã«ãããªã¬ãŒããèŠçŽ ã«å¯ŸããŠçžå¯Ÿçã«é 眮ãããå Žåãªã©ã§ãã
ããããé 眮ã®ããã«JavaScriptã«å€§ããäŸåãããšãPopover APIãæã€ãã€ãã£ããªã¢ã¯ã»ã·ããªãã£ãåäœã®å©ç¹ãæãªãããå¯èœæ§ãããããšã念é ã«çœ®ããŠãã ãããå¯èœãªéãCSSããŒã¹ã®é 眮ã䜿çšããããã«åªããŸãããã
Popoverã®å±æ§ãšç¶æ
Popover APIã¯ãã¢ãŒãã«ã®åäœãå¶åŸ¡ããããã«äžå¯æ¬ ãªããã€ãã®æ°ãã屿§ãšç¶æ ãå°å ¥ããŸãïŒ
popover
: ãã®å±æ§ã¯èŠçŽ ãããããªãŒããŒã«ããŸããå€ã«ã¯auto
ïŒããã©ã«ãã®ããããªãŒããŒåäœïŒãŸãã¯manual
ïŒè¡šç€º/é衚瀺ã«JavaScriptãå¿ èŠïŒããããŸããã¢ãŒãã«ã®å Žåãéåžžã¯popover=auto
ãé©åã§ããpopovertarget
: ãã¿ã³ãªã©ã®ã€ã³ã¿ã©ã¯ãã£ãèŠçŽ ã«èšå®ããã©ã®ããããªãŒããŒãå¶åŸ¡ããããæå®ããŸããpopovertoggletarget
: ãã¿ã³ã察象ã®ããããªãŒããŒã®è¡šç€ºãšé衚瀺ã®äž¡æ¹ãè¡ãããšãæå®ããŸããpopovershowtarget
: 察象ã®ããããªãŒããŒãæç€ºçã«è¡šç€ºããŸããpopoverhidetarget
: 察象ã®ããããªãŒããŒãæç€ºçã«é衚瀺ã«ããŸãã:popover-open
: ããããªãŒããŒã衚瀺ãããŠãããšãã«é©çšãããCSSç䌌ã¯ã©ã¹ã§ãã
å®è£ äŸïŒã·ã³ãã«ãªã¢ãŒãã«
Popover APIã䜿çšããŠã·ã³ãã«ãªã¢ãŒãã«ãäœæããŠã¿ãŸãããïŒ
Modal Title
This is the content of the modal.
[popover] {
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
background-color: white;
padding: 20px;
border-radius: 5px;
box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
border: 1px solid #ccc;
min-width: 300px;
}
[popover]:not(:popover-open) {
display: none;
}
[popover]::backdrop {
background-color: rgba(0, 0, 0, 0.5);
}
ãã®ã³ãŒãã¯ãã¯ãªãã¯ãããšã¢ãŒãã«ãéããã¿ã³ãäœæããŸããã¢ãŒãã«ã¯CSSã䜿çšããŠãã¥ãŒããŒãã®äžå€®ã«é
眮ãããŸãã:not(:popover-open)
ã»ã¬ã¯ã¿ã¯ãã¢ãŒãã«ãåæç¶æ
ã§é衚瀺ã«ãªãããšãä¿èšŒããŸãã
é«åºŠãªã¢ãŒãã«ã®äŸãšèæ ®äºé
åçã³ã³ãã³ããæã€ã¢ãŒãã«
APIããååŸããããŒã¿ããŠãŒã¶ãŒå ¥åã«åºã¥ããŠçæãããåçãªã³ã³ãã³ããã¢ãŒãã«ã«è¡šç€ºããå¿ èŠããããããããŸããããã®ãããªå Žåãã¢ãŒãã«ã衚瀺ããåã«JavaScriptã䜿çšããŠã³ã³ãã³ããæŽæ°ããå¿ èŠããããŸãã
Data Modal
Loading...
document.getElementById('load-data-button').addEventListener('click', async () => {
const dataContainer = document.getElementById('data-container');
try {
const response = await fetch('https://api.example.com/data'); // Replace with your API endpoint
const data = await response.json();
dataContainer.innerHTML = JSON.stringify(data, null, 2); // Display formatted JSON
// Manually show the popover, as the popovertarget will only show it on the *first* click in some browsers.
const modal = document.getElementById('data-modal');
if (!modal.matches(':popover-open')) {
modal.showPopover();
}
} catch (error) {
dataContainer.innerHTML = 'Error loading data.';
console.error(error);
}
});
ãã®äŸã§ã¯ãAPIããããŒã¿ãååŸãããããã¢ãŒãã«ã«è¡šç€ºããŸãã'https://api.example.com/data'
ãå®éã®APIãšã³ããã€ã³ãã«çœ®ãæããããšãå¿ããªãã§ãã ããã
ãã©ãŒã«ã¹ãšã¢ã¯ã»ã·ããªãã£ã®åŠç
Popover APIã¯ã¢ãŒãã«å ã®ãã©ãŒã«ã¹ãã©ãããèªåçã«åŠçããŸããããã¯ã¢ã¯ã»ã·ããªãã£ã«ãšã£ãŠéåžžã«éèŠã§ããããããããã§ãã¢ãŒãã«ã®ã³ã³ãã³ããè«ççã«æ§æãããããŒããŒãããã²ãŒã·ã§ã³ãã·ãŒã ã¬ã¹ã§ããããšã確èªããå¿ èŠããããŸãã
äž»ãªèæ ®äºé ã¯æ¬¡ã®ãšããã§ãïŒ
- èŠåºãã®éå±€ïŒ ã³ã³ãã³ããæ§é åããããã«ãé©åãªèŠåºãã¬ãã«ïŒ
<h1>
ã<h2>
ãªã©ïŒã䜿çšããŠãã ããã - ããŒããŒãããã²ãŒã·ã§ã³ïŒ ã¢ãŒãã«å ã®ãã¹ãŠã®ã€ã³ã¿ã©ã¯ãã£ãèŠçŽ ããã©ãŒã«ã¹å¯èœã§ãããŒããŒãã䜿çšããŠããã²ãŒãã§ããããšã確èªããŠãã ããã
- ARIA屿§ïŒ å¿ èŠã«å¿ããŠã¹ã¯ãªãŒã³ãªãŒããŒã«è¿œå æ å ±ãæäŸããããã«ARIA屿§ã䜿çšããŠãã ãããPopover APIã¯åºæ¬çãªã¢ã¯ã»ã·ããªãã£ãåŠçããŸãããARIA屿§ã¯æ¯æŽæè¡ãŠãŒã¶ãŒã®äœéšãããã«åäžãããããšãã§ããŸãããã ããåé·ãªARIA屿§ã¯é¿ããŠãã ããã
- èšèªå±æ§ïŒ ããŒãžã®èšèªãæå®ããããã«
<html>
ã¿ã°ã«lang
屿§ã䜿çšããããããªãŒããŒèªäœãç°ãªãèšèªã®å Žåã¯ãã®å éšã§ã䜿çšããŠãã ããã
å€ããã©ãŠã¶ãžã®å¯Ÿå¿
Popover APIã¯æ¯èŒçæ°ããããããã©ãŠã¶ã®äºææ§ãèæ ®ããããšãäžå¯æ¬ ã§ããå€ããã©ãŠã¶ã¯APIããã€ãã£ãã«ãµããŒãããŠããªãå¯èœæ§ããããŸãããããã®ãã©ãŠã¶ããµããŒãããããã«ãããªãã£ã«ã䜿çšã§ããŸããPopover Polyfillãè¯ãéžæè¢ã§ãã
<script src="https://cdn.jsdelivr.net/npm/popover-polyfill@latest/dist/index.min.js"></script>
HTMLã«ããªãã£ã«ã®ã¹ã¯ãªãããå«ããããšã§ãPopover APIãããŸããŸãªãã©ãŠã¶ã§äžè²«ããŠåäœããããšãä¿èšŒã§ããŸãã
CSS Popover APIã䜿çšããããã®ãã¹ããã©ã¯ãã£ã¹
- CSSããŒã¹ã®é 眮ãåªå ããïŒ APIã®ãã€ãã£ããªã¢ã¯ã»ã·ããªãã£æ©èœã掻çšããããã«ãå¯èœãªéãã¢ãŒãã«ã®é 眮ã«ã¯CSSã䜿çšããŠãã ããã
- JavaScriptã¯æå°éã«ä¿ã€ïŒ ããããªãŒããŒã®åäœç®¡çã«é床ãªJavaScriptã䜿çšããã®ã¯é¿ããŠãã ãããåçãªã³ã³ãã³ããè€éãªã€ã³ã¿ã©ã¯ã·ã§ã³ãªã©ãå¿ èŠãªå Žåã«ã®ã¿JavaScriptã䜿çšããŸãã
- 培åºçã«ãã¹ãããïŒ ããŸããŸãªãã©ãŠã¶ãããã€ã¹ã§ã¢ãŒãã«ããã¹ãããäžè²«ããåäœãšã¢ã¯ã»ã·ããªãã£ã確ä¿ããŠãã ããã
- åœéåïŒi18nïŒãèæ ®ããïŒ ã¢ãŒãã«ããã¶ã€ã³ã»é 眮ããéã«ã¯ãããã¹ãã®æ¹åïŒLTR/RTLïŒãæåçãªéãã«æ³šæããŠãã ãããäŸãã°ãäžéšã®RTLèšèªã§ã¯ããéããããã¿ã³ãå³ã§ã¯ãªãå·Šã«é 眮ãããããšããããŸãã
- ã»ãã³ãã£ãã¯HTMLã䜿çšããïŒ ã¢ã¯ã»ã·ããªãã£ãšä¿å®æ§ãåäžãããããã«ãã»ãã³ãã£ãã¯ãªHTMLèŠçŽ ïŒäŸïŒããå©çšå¯èœã§ããã°ãåçŽãªããããªãŒããŒã§ã¯ãªããã€ã¢ãã°ãšããŠæ±ãããã¹ãã¢ãŒãã«ã«ã¯
<dialog>
ïŒã䜿çšããŠãã ããã - ããã©ãŒãã³ã¹ãæé©åããïŒ ããã©ãŒãã³ã¹ã«æªåœ±é¿ãäžããå¯èœæ§ã®ããè€éãªCSSèšç®ãã¢ãã¡ãŒã·ã§ã³ã¯é¿ããŠãã ããã
- ãšããžã±ãŒã¹ãåŠçããïŒ ã¢ãŒãã«ããããµããå¯èœæ§ã®ããéåžžã«é·ãã³ã³ãã³ãããã¢ãŒãã«ãé©åã«åãŸããªãå°ããªç»é¢ãªã©ã®ãšããžã±ãŒã¹ãèæ ®ããŠãã ããã
Popover APIã䜿çšããå©ç¹
CSS Popover APIãæ¡çšããããšã«ã¯ãããã€ãã®å©ç¹ããããŸãïŒ
- ã¢ã¯ã»ã·ããªãã£ã®åäžïŒ ãã€ãã£ããªã¢ã¯ã»ã·ããªãã£ãµããŒãã«ãããé害ãæã€ãŠãŒã¶ãŒãå«ããã¹ãŠã®äººãã¢ãŒãã«ã䜿çšã§ããããã«ãªããŸãã
- éçºã®ç°¡çŽ åïŒ ãã®APIã¯ãããããªãŒããŒã®äœæãšç®¡çã«å¿ èŠãªJavaScriptã³ãŒãã®éãåæžããŸãã
- ããã©ãŒãã³ã¹ã®åäžïŒ ãã€ãã£ããªãã©ãŠã¶ãµããŒãã«ãããJavaScriptããŒã¹ã®ãœãªã¥ãŒã·ã§ã³ãšæ¯èŒããŠããã©ãŒãã³ã¹ãåäžããå¯èœæ§ããããŸãã
- æšæºåãããåäœïŒ ãã®APIã¯ããããªãŒããŒãäœæããããã®æšæºåãããæ¹æ³ãæäŸããããŸããŸãªãã©ãŠã¶ããã©ãããã©ãŒã ã§äžè²«ããåäœãä¿èšŒããŸãã
é¿ããã¹ãããããééã
- JavaScriptãžã®é床ãªäŸåïŒ é 眮ãããããªãŒããŒã®åäœç®¡çã«JavaScriptãå€çšãããšãAPIã®å©ç¹ã倱ãããå¯èœæ§ããããŸãã
- ã¢ã¯ã»ã·ããªãã£ã®ç¡èŠïŒ ã¢ãŒãã«ã®ã³ã³ãã³ããé©åã«æ§é åãããã©ãŒã«ã¹ç®¡çãæ ããšãã¢ã¯ã»ã·ããªãã£ã®åé¡ãçºçããå¯èœæ§ããããŸãã
- ãã©ãŠã¶äºææ§ã®è»œèŠïŒ å€ããã©ãŠã¶ãèæ ®ãããããªãã£ã«ã䜿çšããªããšãäžè²«æ§ã®ãªãåäœã«ã€ãªããå¯èœæ§ããããŸãã
- äžé©åãªé 眮ã®éžæïŒ éèŠãªã³ã³ãã³ããé ããããæäœãå°é£ã«ãªã£ãããããããªæ¹æ³ã§ã¢ãŒãã«ãé 眮ãããšããŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ãäœäžããå¯èœæ§ããããŸãã
- ãã©ãŒã«ã¹ãã©ããã®äžé©åãªåŠçïŒ APIã¯ãã©ãŒã«ã¹ãã©ãããè£å©ããŸãããã¢ãŒãã«å ã®ãã¹ãŠã®ãã©ãŒã«ã¹å¯èœãªèŠçŽ ãããŒããŒãã§å°éå¯èœã§ããããšããããŠã¢ãŒãã«ãéãããããšãã«ãã©ãŒã«ã¹ãããªã¬ãŒèŠçŽ ã«æ»ãããšãä¿èšŒããããšãéèŠã§ãã
Popover APIã®ä»£æ¿æ¡
Popover APIã¯æè¿ãã¹ãè¿œå æ©èœã§ãããããããã«é·æãšçæãããä»£æ¿æ¡ãååšããŸããäžè¬çãªä»£æ¿æ¡ã«ã¯ä»¥äžã®ãããªãã®ããããŸãïŒ
- JavaScriptã©ã€ãã©ãªïŒ jQuery UIãBootstrapãªã©ã®ã©ã€ãã©ãªãããã³ã«ã¹ã¿ã JavaScriptãœãªã¥ãŒã·ã§ã³ã¯ãåŸæ¥ããã¢ãŒãã«ã®äœæã«äœ¿çšãããŠããŸããããããã®ãœãªã¥ãŒã·ã§ã³ã¯æè»æ§ãæäŸããŸãããå€ãã®å Žåãããå€ãã®ã³ãŒããå¿ èŠãšãããã€ãã£ããœãªã¥ãŒã·ã§ã³ãããã¢ã¯ã»ã·ããªãã£ãäœããªãå¯èœæ§ããããŸãã
- <dialog>èŠçŽ ïŒ
<dialog>
èŠçŽ ã¯ããã€ã¢ãã°ããã¯ã¹ãã¢ãŒãã«ãŠã£ã³ããŠãã»ãã³ãã£ãã¯ã«è¡šçŸããæ¹æ³ãæäŸããŸããããã€ãã®çµã¿èŸŒã¿ã¢ã¯ã»ã·ããªãã£æ©èœãæäŸããŸãããã¹ã¿ã€ãªã³ã°ãé 眮ã®é¢ã§ã¯Popover APIã»ã©æè»ã§ã¯ãªããããããŸããããã ããã»ãã³ãã£ãã¯ãªæ§é ãæäŸããããã«Popover APIãšçµã¿åãããŠäœ¿çšããããšãæšå¥šãããŸãã
çµè«
CSS Popover APIã¯ãã¢ã¯ã»ã·ãã«ã§ããã©ãŒãã³ã¹ã®é«ãããããªãŒããŒïŒã¢ãŒãã«ãå«ãïŒãäœæããããã®åŒ·åã§æšæºåãããæ¹æ³ãæäŸããŸããAPIã®æ©èœã掻çšãããã¹ããã©ã¯ãã£ã¹ã«åŸãããšã§ãããã³ããšã³ãéçºã®ã¯ãŒã¯ãããŒãç°¡çŽ åããããè¯ããŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ãçã¿åºãããšãã§ããŸããäžéšã®é«åºŠãªã·ããªãªã§ã¯äŸç¶ãšããŠJavaScriptãå¿ èŠã«ãªããããããŸããããPopover APIã¯ã¢ãŒãã«éçºã«ãããŠCSSäžå¿ã®ã¢ãããŒããæšå¥šããŸããPopover APIã®ãã©ãŠã¶ãµããŒããåäžãç¶ããã«ã€ããŠããŠã§ãäžã§ããããªãŒããŒãã¢ãŒãã«ãäœæããããã®å¥œãŸããæ¹æ³ã«ãªãå¯èœæ§ãé«ãã§ãã
Popover APIãæŽ»çšãããã€ãã£ããªã¢ãŒãã«é 眮ã®å¯èœæ§ãè§£ãæŸã¡ãŸãããïŒ