html,CSS,javascript 做一個彈窗

来源:https://www.cnblogs.com/makeupforever-carrie/archive/2018/08/10/9456409.html
-Advertisement-
Play Games

彈窗的工作原理:在網頁中寫一個div ,佈局到想要顯示的位置,將display設為none,隱藏該div。然後通過點擊事件或其他操作,利用Js代碼,將display設置為block,將div 顯示到網頁中。 Tips:display:none//隱藏 display: block//顯示 效果圖:點 ...


彈窗的工作原理:在網頁中寫一個div ,佈局到想要顯示的位置,將display設為none,隱藏該div。然後通過點擊事件或其他操作,利用Js代碼,將display設置為block,將div 顯示到網頁中。

Tips:display:none//隱藏   display: block//顯示

效果圖:點擊彈出一個彈窗按鈕,顯示彈窗內容

代碼:

<!doctype html>
<html>
<head>
    <title>彈窗練習</title>
    <meta charset="utf-8">
    <style>
        .btn-pop{
            background-color: #ffd475;  
            border-radius: 10px;
            border:0px;
            zoom:200%;

        }
        #background-pop{
            display: none;
            position: fixed;
            left: 0;
            top: 0;
            width: 100%;
            height: 100%;
            background-color: rgba(0,0,0,0.5);
        }
        #div-pop{
            background:#ffffff;
            width:30%;
            z-index: 1;
            margin: 12% auto;
            overflow: auto;
        }
        .div-top{
            width: 100%;
            height: auto;
            background-color: #28a3e7;
            color: #ffffff;
        }
        .div-top div{
            padding: 3px 5px 5px 8px;
        }
        span{
            color: white;
            margin-bottom: 10px ;
            margin-left: 20px ;
            cursor: pointer;
            float: right;
        }
        .div-content{
            width: auto;
            height: 200px;
            overflow: auto;
        }
        .div-footer{
            text-align: center;
            background-color: darkgray;
        }
    </style>
</head>
<body>
    <button class="btn-pop" onclick="show()">彈出一個視窗</button>
    <div id="background-pop">
        <div id="div-pop">
            <div class="div-top">
                <span id="close-button">×</span>
                <div>彈窗頂部(可以寫個標題)</div>
            </div>
            <div class="div-content">
                放點內容進來<br>
                點擊灰色位置和右上角x關閉彈窗
            </div>
            <div class="div-footer">
                底部內容
            </div>
        </div>
    </div>
</body>
<script>
        var div = document.getElementById('background-pop');
        var close = document.getElementById('close-button');
        function show(){
            div.style.display = "block";
        }
        close.onclick = function close() {
            div.style.display = "none";
        }
        window.onclick = function close(e) {
            if (e.target == div) {
                div.style.display = "none";
            }
        }
</script>
</html>

代碼:內容同上,多加了詳細註釋

<!doctype html>
<html>
<head>
    <title>彈窗練習</title>
    <meta charset="utf-8">
    <style>     <!-- css樣式 -->
        .btn-pop{   <!-- class選擇器btn-pop添加樣式 -->
            background-color: #ffd475;  <!-- 設置背景顏色 -->
            border-radius: 10px;    <!-- 按鈕設置個圓角 -->
            border:0px; <!-- 去掉邊框 -->
            zoom:200%;  <!-- 按鈕變大兩倍 -->

        }
        #background-pop{    <!-- id選擇器background-pop添加樣式 -->
            display: none;  <!-- 設置隱藏 -->
            position: fixed;    <!-- 相對於瀏覽器視窗的絕對定位,absolute 相對於屏幕 -->
            left: 0;    <!-- 視窗距離右端 -->
            top: 0; <!-- 視窗距離頂部 -->
            width: 100%;   <!-- 寬  100% 填充整個視窗 -->
            height: 100%;   <!-- 高  -->
            background-color: rgba(0,0,0,0.5);  <!-- 設置北京顏色(red,green,blue alpha)  -->
        }
        #div-pop{   <!-- id選擇器 -->
            background:#ffffff; <!-- 背景色 -->
            width:30%;  <!-- 寬 -->
            z-index: 1; <!-- 設置堆疊順序,參數大的在前,預設為0 -->
            margin: 12% auto;   <!-- 外邊距 -->
            overflow: auto; <!-- 超過設置大小固定時,超過時,以滾動條顯示 -->
        }
        .div-top{   <!-- class選擇器div-top -->
            width: 100%;    <!-- 寬 -->
            height: auto;   <!-- 高 預設高度隨內部元素高度變化 -->
            background-color: #28a3e7; <!-- 背景顏色 -->
            color: #ffffff; <!-- 字體顏色 -->
        }
        .div-top div{   <!-- class選擇器div-top 中的div設置樣式 -->
            padding: 3px 5px 5px 8px; <!-- 內邊距 :上 右 下 左, -->
        }
        span{   <!-- span標簽添加樣式 -->
            color: white;   <!-- 顏色 -->
            margin-bottom: 10px ;   <!-- 底部外邊距 -->
            margin-left: 20px ; <!-- 左側外邊距 -->
            cursor: pointer;    <!-- 滑鼠指到此處顯示為手行 -->
            float: right;   <!-- 浮動:靠右 -->
        }
        .div-content{   <!-- class選擇器div-content -->
            width: auto;    <!-- 寬 -->
            height: 200px;  <!-- 高 固定值 -->
            overflow: auto; <!-- 加滾動 -->
        }
        .div-footer{    <!-- class選擇器 -->
            text-align: center; <!-- 文字居中 -->
            background-color: darkgray; <!-- 背景色 -->
        }
    </style>
</head>
<body>
    <button class="btn-pop" onclick="show()">彈出一個視窗</button> <!-- 添加一個按鈕 ,onclick事件,點擊調用JavaScript中的 show()函數-->
    <div id="background-pop"> <!-- 設置id 以便操作和添加樣式 -->
        <div id="div-pop">  <!-- 彈窗對應的div -->
            <div class="div-top">   <!-- 彈窗頂部對應的div -->
                <span id="close-button">×</span>
                <div>彈窗頂部(可以寫個標題)</div>
            </div>
            <div class="div-content">   <!-- 彈窗中間對應的div -->
                放點內容進來<br>
                點擊灰色位置和右上角x關閉彈窗
            </div>
            <div class="div-footer">    <!-- 彈窗底部對應的div -->
                底部內容
            </div>
        </div>
    </div>
</body>
<!-- 彈窗的js -->
<script>
        var div = document.getElementById('background-pop'); //聲明 div,通過元素id獲取節點,為了後續對id選擇器background-pop對應的樣式進行操作
        var close = document.getElementById('close-button');  //聲明 close 通過元素id獲取節點,以便為close添加onclick事件
        function show(){    //函數show()將background-pop中的display屬性設置為block ,使隱藏的div顯示
            div.style.display = "block";
        }
        close.onclick = function close() {  // 點擊視窗右上角 ×關閉彈窗;將background-pop中的display屬性設置為none ,使其隱藏
            div.style.display = "none";
        }
        window.onclick = function close(e) {//點擊頁面中灰色部分關閉彈窗;將background-pop中的display屬性設置為none ,使其隱藏
            if (e.target == div) {
                div.style.display = "none";
            }
        }
</script>
</html>

  

over!!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • List<Integer> integerList = new ArrayList<>(); 當我們要移除某個Item的時候 remove(int position):移除某個位置的Item remove(object object):移除某個對象 那麼remove(12)到底是移除第12的item ...
  • 1.java.lang.NoSuchMethodError: android.content.res.Resources.getDrawable/getColor或者 java.lang.NoSuchMethodError:android.content.Context.getDrawable/ge ...
  • 最近在做一個Xamarin for android的項目,有個需求是一次可以從相冊中選擇多張圖片,但是 android API<19 的版本還不支持一次選擇多張圖片,在網找了一下,發現原生的組件有很多並且都非常好用,也找到了很多原生的通過Binding 技術生成的 Xamarin for andro ...
  • 最近做了一個關於vue.js的小demo: 當用戶登錄時,使用狀態保存vuex將用戶的頭像信息存儲到store.state當中,這樣不同用戶登錄就會顯示相應的頭像。 具體實現方法: 在組件的計算屬性當中通過 this.$store.getters.userImg 獲取當前用戶的頭像,然後用requi ...
  • 在程式設計中有很多實用的設計模式,而其中大部分語言的實現都是基於“類”。 在JavaScript中並沒有類這種概念,JS中的函數屬於一等對象,在JS中定義一個對象非常簡單(var obj = {}),而基於JS中閉包與弱類型等特性,在實現一些設計模式的方式上與眾不同。 本文基於《JavaScript ...
  • 從場景說起 滑動到底部繼續載入,是移動端很常見的一種場景。 通常來說,我們會在對可滑動區域(一般是window)的scroll事件做監聽,判斷距離底部還有多遠,如果距離底部較近,則發起HTTP請求,請求下一頁的數據。 很容易寫出這樣的代碼: 但是這樣很容易就發現一個問題,觸發的scroll事件太頻繁 ...
  • 開題先拋一個快應用的開發文檔鏈接 https://doc.quickapp.cn/ 我只能說這個文檔不是很人性化,左側導航欄分了『指南和參考』,結果我最關心的組件,在『指南』中只有list和tabs,其餘組件都在『參考』中,真是噴了一口老血才找到。 根據開發微信小程式和支付寶小程式的經驗,我習慣性的 ...
  • JavaScript 對象是動態的屬性“包”(指其自己的屬性)。JavaScript 對象有一個指向一個原型對象的鏈。當試圖訪問一個對象的屬性時,它不僅僅在該對象上搜尋,還會搜尋該對象的原型,以及該對象的原型的原型,依次層層向上搜索,直到找到一個名字匹配的屬性或到達原型鏈的末尾。 遵循ECMAScr ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...