搜尋
首頁web前端css教學Popover API:使用 HTML 建立本機彈出視窗 - 無需 JavaScript

新的 Popover API:無需 JavaScript 即可輕鬆實作 Popover

Popover API 簡化了 popover 的創建,消除了對 JavaScript 函式庫或手動編碼的需求。 跨主要瀏覽器支持,非常容易實現。

了解 Popover API

Popover API: Create Native Pop-Ups with HTML—No JavaScript Needed

這個新標準簡化了顯示彈出視窗、自動處理開啟、關閉和可訪問性注意事項的過程。 開發者不再需要獨立管理這些狀態。

建立彈出視窗

基本實作

以下是建立基本彈出視窗的方法:

  1. 在 HTML 中建立一個按鈕來觸發彈出視窗。
  2. 在按鈕上使用 popover-target 屬性,透過共用 ID(例如 popover)將其連結到元素。
  3. 使用相同的 ID 將 popover 屬性套用到要用作彈出視窗的 HTML 元素。

僅此而已!單擊該按鈕將打開彈出窗口,當您單擊外部(輕關閉)時,它會自動關閉。此切換功能是預設行為。

新增關閉按鈕

您可以在彈出視窗中新增關閉按鈕。 為該按鈕提供適當的 popover-target 屬性並明確定義 hide 操作。 一點 CSS 會增強它的外觀。

彈出模式

彈出視窗預設為「自動」模式:

  1. 開啟彈出視窗會關閉所有其他開啟的彈出視窗。
  2. 輕微消除已啟用。

切換到「手動」模式可防止自動關閉其他彈出視窗並停用燈光關閉。您需要明確管理彈出視窗的開啟和關閉。

設計彈出框

使用背景元素

backdrop 元素特別有用;當彈出視窗打開時,它會覆蓋頁面的其餘部分。

[popover] {
    background: white;
    border: 1px solid #ccc;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    padding: 16px;
    max-width: 300px;
}

/* ... other CSS ... */

這樣可以輕鬆設定背景樣式,將注意力集中在彈出視窗上。

Popover 與 Modal

了解彈出視窗不是模態框是至關重要的:

  1. 彈出視窗不會停用與頁面其餘部分的互動。
  2. 當彈出視窗開啟時,您仍然可以點擊其他元素。

對於需要使用者互動才能繼續操作的模式,請使用 dialog.showModal() 代替。 這將需要一些 JavaScript,但它提供了真正的模式功能。

增強 Popover 樣式

使用對話元素

popover 屬性本身是非語義的,允許您為彈出視窗使用 HTML <dialog></dialog> 元素。

增加更多內容並套用 CSS

添加更多內容(按鈕等)和 CSS 樣式(字體系列、填充、顏色等)進一步增強了彈出框的外觀。 此範例展示如何設定主按鈕的樣式以獲得更美觀的外觀。

將 JavaScript 與 Popover 結合使用

雖然 API 無需 JavaScript 即可簡化彈出視窗的創建,但您仍然可以使用 JavaScript 進行更高級的控制(例如 showPopover)。

結論

Popover API 提供了一種簡化的方法,可以用最少的程式碼建立優雅且易於存取的 popover。 歡迎您的回饋! 考慮喜歡或關注更多這樣的內容。

追蹤我:LinkedIn | | 藍天

以上是Popover API:使用 HTML 建立本機彈出視窗 - 無需 JavaScript的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
CSS Flexbox與網格:全面評論CSS Flexbox與網格:全面評論May 12, 2025 am 12:01 AM

選擇Flexbox還是Grid取決於佈局需求:1)Flexbox適用於一維佈局,如導航欄;2)Grid適合二維佈局,如雜誌式佈局。兩者在項目中可結合使用,提升佈局效果。

Flexbox vs Grid:我應該學習兩者嗎?Flexbox vs Grid:我應該學習兩者嗎?May 10, 2025 am 12:01 AM

是的,youshouldlearnbothflexboxandgrid.1)flexboxisidealforone-demensional,flexiblelayoutslikenavigationmenus.2)gridexcelstcelsintwo-dimensional,confffferDesignssignssuchasmagagazineLayouts.3)blosebothenHancesSunHanceSlineHancesLayOutflexibilitibilitibilitibilitibilityAnderibilitibilityAndresponScormentilial anderingStruction

軌道力學(或我如何優化CSS KeyFrames動畫)軌道力學(或我如何優化CSS KeyFrames動畫)May 09, 2025 am 09:57 AM

重構自己的代碼看起來是什麼樣的?約翰·瑞亞(John Rhea)挑選了他寫的一個舊的CSS動畫,並介紹了優化它的思維過程。

CSS動畫:很難創建它們嗎?CSS動畫:很難創建它們嗎?May 09, 2025 am 12:03 AM

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

@KeyFrames CSS:最常用的技巧@KeyFrames CSS:最常用的技巧May 08, 2025 am 12:13 AM

@keyframesispopularduetoitsversatoryand and powerincreatingsmoothcsssanimations.keytricksinclude:1)definingsmoothtransitionsbetnestates,2)使用AnimatingMultatingMultationMultationProperPertiessimultane,3)使用使用4)使用BombingeNtibalibility,4)使用CombanningWiThjavoFofofofoftofofo

CSS計數器:自動編號的綜合指南CSS計數器:自動編號的綜合指南May 07, 2025 pm 03:45 PM

CSSCOUNTERSAREDOMANAGEAUTOMANAMBERINGINWEBDESIGNS.1)他們可以使用forterablesofcontents,ListItems,and customnumbering.2)AdvancedsincludenestednumberingSystems.3)挑戰挑戰InclassINCludeBrowsEccerCerceribaliblesibility andperformiballibility andperformissises.4)創造性

使用捲軸驅動動畫的現代滾動陰影使用捲軸驅動動畫的現代滾動陰影May 07, 2025 am 10:34 AM

使用滾動陰影,尤其是對於移動設備,是克里斯以前涵蓋的一個微妙的UX。傑夫(Geoff)涵蓋了一種使用動畫限制屬性的新方法。這是另一種方式。

重新訪問圖像圖重新訪問圖像圖May 07, 2025 am 09:40 AM

讓我們快速進修。圖像地圖一直返回到HTML 3.2,首先是服務器端地圖,然後使用映射和區域元素通過圖像上的單擊區域定義了可單擊區域。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境