站長資訊網
        最全最豐富的資訊網站

        javascript怎么實現彈出層

        javascript實現彈出層的方法:1、創建一個HTML示例文件;2、將待顯示的內容先隱藏,在觸發點擊條件后,將原本隱藏的內容顯示出來,代碼如“document.getElementById("open").onclick = function(e){…}”;3、提供遮罩層將原先的頁面內容全部遮住即可。

        javascript怎么實現彈出層

        本教程操作環境:Windows10系統、javascript1.8.5版本、Dell G3電腦。

        javascript怎么實現彈出層?

        使用JAVASCRIPT實現彈出層效果

        聲明

        閱讀本文需要有一定的HTML、CSS和JavaScript基礎

        設計

        實現彈出層效果的思路非常簡單:將待顯示的內容先隱藏,在觸發某種條件后(如點擊按鈕),將原本隱藏的內容顯示出來。

        實現

        <!DOCTYPE html> <html> <head>     <title>Window對象</title>     <meta charset="utf-8"> </head> <body> <a href="http://www.baidu.com">百度一下</a> <button type="button" id="open">打開彈出層</button> <div style="display: none;background: lightblue;border:1px solid green;" id="toast">         <!--     設置display屬性為none以隱藏內容             -->     <p>這里是彈出層內容</p>     <button type="button" id="close">關閉彈出層</button> </div> <script type="text/javascript">     var toast = document.getElementById("toast");     document.getElementById("open").onclick = function(e){           <!--    定義點擊事件顯示隱藏內容          -->         toast.style.display = "block";         toast.style.position = "fixed";         var winWidth = window.innerWidth;         var winHeight = window.innerHeight;         var targetWidth = toast.offsetWidth;         var targetHeight = toast.offsetHeight;         toast.style.top = (winHeight - targetHeight) / 2 + "px";         toast.style.left = (winWidth - targetWidth) / 2 + "px";     }     document.getElementById("close").onclick = function(e){               <!--      將顯示的內容再次隱藏         -->         toast.style.display = "none";     } </script> </body> </html>
        登錄后復制

        顯示效果如下:

        javascript怎么實現彈出層

        但是我們可以注意到,在彈出隱藏內容之后我們還是可以通過鏈接進入百度頁面。為了防止這種情況的發生,我們可以提供遮罩層將原先的頁面內容全部遮住。代碼如下:

        <!DOCTYPE html> <html> <head>     <title>Window對象</title>     <meta charset="utf-8"> </head> <body> <a href="http://www.baidu.com">百度一下</a> <button type="button" id="open">打開彈出層</button> <div id="cover" style="display: none;position: fixed;width: 100%;height: 100%;top:0px;left:0px;background: gray;">       <!-- 通過遮罩層遮住背景 -->     <div style="background: lightblue;border:1px solid green;" id="toast">         <!-- 設置display屬性為none以隱藏內容             -->      <p>這里是彈出層內容</p>       <button type="button" id="close">關閉彈出層</button>   </div> </div> <script type="text/javascript">     var toast = document.getElementById("toast");     var cover = document.getElementById("cover");     document.getElementById("open").onclick = function(e){           <!--    定義點擊事件顯示隱藏內容          -->         cover.style.display = "block";         toast.style.position = "fixed";         var winWidth = window.innerWidth;         var winHeight = window.innerHeight;         var targetWidth = toast.offsetWidth;         var targetHeight = toast.offsetHeight;         toast.style.top = (winHeight - targetHeight) / 2 + "px";         toast.style.left = (winWidth - targetWidth) / 2 + "px";     }     document.getElementById("close").onclick = function(e){               <!--      將顯示的內容再次隱藏         -->         cover.style.display = "none";     } </script> </body> </html>
        登錄后復制

        這是再次測試下效果,如下圖:

        javascript怎么實現彈出層

        總結

        上述內容只是簡單實現了彈出層效果,但是通過添加

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 亚洲AV永久精品爱情岛论坛| 国产韩国精品一区二区三区久久| 欧美精品v国产精品v日韩精品| 亚洲综合精品香蕉久久网97| 国产精品99久久99久久久| 精品国产婷婷久久久| 免费视频精品一区二区三区| 国产精品久久久久国产A级| 亚洲午夜精品久久久久久浪潮| 国产亚洲午夜高清国产拍精品| 欧美成人精品一区二区三区| 国产成人精品优优av| 人妻少妇偷人精品无码| 中文字幕精品无码一区二区 | 久久精品国产精品亚洲人人 | 久久精品国产精品亚洲下载| 国产91精品黄网在线观看| 久久精品成人免费网站| 99re6在线精品免费观看| 国产精品女同一区二区| 久久亚洲私人国产精品vA| 亚洲国产精品一区第二页| 午夜国产精品无套| 日韩精品无码永久免费网站| 久久精品国产亚洲AV不卡| 精品国产综合区久久久久久| 国产精品亚洲欧美大片在线观看| 中文字幕亚洲精品| 99久久国产主播综合精品| 99久久99久久精品国产| 国产成人高清精品免费观看| 91精品无码久久久久久五月天| 欧美大片日韩精品| 999久久久免费国产精品播放| 99精品久久久久久久婷婷| 国产精品内射婷婷一级二| 国产精品H片在线播放| 国内精品国语自产拍在线观看| 国产午夜亚洲精品国产成人小说 | 国产精品无码一区二区在线| 国产精品内射婷婷一级二|