• js模态弹窗


    一.实现弹窗原理:

        

    弹窗的实现:

          (1)先写出一个div,弹出窗的样式,然后使用display样式进行隐藏;

          (2)当点击登录时,弹出窗口,这时display样式变为block

          (3)遮罩层的实现,使用一个div,让它占据整个屏幕,刚开始时隐藏,当点击登录时,遮罩层的display样式变为block,只是设计时,让遮罩层的z-index的值,小于弹窗的Z-index值,确保弹窗在屏幕的最上层。

          (4)弹窗位置的实现中,还使用了document.documentElement.clientHeight,document.documentElement.clientWidth,来实现随着屏幕大小的变化,使弹框始终位于屏幕的中间位置。

    二.具体实现:

      html代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    <header>
        <img src="../img/logoo.png" alt="图标">
        <ul id="menu">
            <li id="menuli"><a href="#">庄园介绍</a>
            </li>
            <li id="menuli2"><a href="#">图片集</a>
            </li>
            <li><a href="#">相关介绍</a>
            </li>
        </ul>
        <div class="login"><a href="#">登录</a>
        </div>
    </header>
    <div id="article">
            <h3>欢迎来到薰衣草庄园</h3>
      
            <h5>放松自己,享受心情</h5>
      
    </div>
    //弹窗的部分html设计
    <div id="login">
         <h2><img src="../img/login_wrong.png" class="close">登录弹窗</h2
        <form action="">
            <div class="form-group">
                <label for="user">用户名</label>
                <input type="text" id="user" name="user" class="form-control" placeholder=" 请输入用户名">
            </div>
            <div class="form-group">
                <label for="pwd">密 码</label>
                <input type="password" id="pwd" name="pwd" placeholder=" 请输入密码" class="form-control">
            </div>
            <button class="btn">登 录</button>    
            <div id="other">    <a href="#">忘记密码</a>|<a href="#">注册用户</a
            </div>
        </form>
    </div>
    //遮罩层的div
    <div id="dropback"></div>

    css代码:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    * {
        margin0;
        padding0;
    }
    body {
        backgroundurl("../img/login_bg.png");
    }
    //遮罩层的css实现
    #dropback {
        positionabsolute;
        top:0;
        left:0;
        right:0;
        bottom0;
        background#444;
        z-index1000;
        opacity: 0.9;
        displaynone;
    }
    //弹窗的css实现
    #login {
        width300px;
        height250px;
        positionabsolute;
        border:1px solid #E5E5E5;
        displaynone;
        z-index100;
        color:#666;
        border-radius: 4px;
        z-index1020;
        background#fff;
    }
    //弹窗上关闭X号按钮的实现
    .close {
        positionrelative;
        float:right;
        top:3px;
        right:5px;
        padding:5px;
        cursorpointer;
    }
    //表单的css实现
    .form-group {
        margin-bottom10px;
        margin-left5px;
    }
    label {
        display: inline-block;
        width20%;
    }
    .form-control {
        width70%;
        height20px;
        padding6px 0;
        font-size14px;
        line-height1.42857143;
        letter-spacing2px;
        color#555;
        background-color#fff;
        border1px solid #ccc;
        border-radius: 4px;
        box-shadow: inset 0 1px 1px rgba(000, .075);
        transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
    }
    .form-control:focus {
        border-color#66afe9;
        outline0;
        box-shadow: inset 0 4px 4px rgba(000, .075), 0 0 8px #F9F8FE;
    }
    .btn {
        display: inline-block;
        width40%;
        margin-left30%;
        margin-top10px;
        padding6px 12px;
        margin-bottom0;
        font-size14px;
        font-weightnormal;
        line-height1.42857143;
        text-aligncenter;
        white-spacenowrap;
        vertical-alignmiddle;
        cursorpointer;
        color#fff;
        background-color#5cb85c;
        border-color#4cae4c;
        border1px solid transparent;
        border-radius: 5px;
    }
    .btn:focus {
        color#fff;
        background-color#449d44;
        border-color#398439;
        text-decorationnone;
    }
    #other {
        float:right;
        margin-top:20px;
    }
    #other a {
        color:#888;
        text-decorationnone;
    }
    #other a:hover {
        color:red;
        text-decorationnone;
    }
    //整体的其他css样式实现
    header {
        width100%;
        height:50px;
        background#FFFEFE;
        border:1px solid #E5E5E5;
    }
    img {
        displayblock;
        float:left;
        /*border-radius: 4px; */
    }
    ul {
        list-style-typenone;
        margin-left:150px;
        text-aligncenter;
    }
    ul>li {
        float:left;
    }
    ul>li>a {
        displayblock;
        text-decorationnone;
        padding:5px 30px;
        color:#666;
        letter-spacing2px;
        line-height40px;
    }
    ul>li>a:hover {
        color:#000;
        background#f1f1f1;
    }
    .login {
        floatright;
        margin-right30px;
        padding15px 0;
        letter-spacing2px;
        cursorpointer;
    }
    .login>a {
        text-decoration:none;
        color#666;
        displayblock;
    }
    .login>a:hover {
        transform: scale(1.5);
        background#f1f1f1;
        color:#000;
    }
     
    #article {
        width400px;
        margin-left20px;
    }
    h3 {
        color:white;
        letter-spacing3px;
        margin:12px;
        text-aligncenter;
        font-size32px;
    }
    h5 {
        color:white;
        letter-spacing3px;
        margin:12px;
        text-alignleft;
        font-size26px;
        text-shadowinset 0 1px 1px rgba(000, .075);
    }
    h2 {
        width100%;
        height30px;
        border-bottom1px solid #e5e5e5;
        text-aligncenter;
        margin-bottom25px;
        letter-spacing2px;
        color:#666;
        background-color#f1f1f1;
        opacity: 0.8;
    }

    js代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    window.onload = function () {
      
        var close = document.getElementsByClassName('close');
        var login = document.getElementById('login');
        var logins = document.getElementsByClassName('login');
        var screen = document.getElementById('dropback');
        var bodyobj = document.body;
      
        function show(obj) {
            //获取浏览器的宽和高
            var top = (document.documentElement.clientHeight - 250) / 2 - 150;
            var left = (document.documentElement.clientWidth - 300) / 2;
            //当点击登录按钮时,登录弹窗出现,遮罩层显示
            screen.style.display = 'block'//遮罩层显示
            obj.style.display = 'block'//登录弹窗出现
            obj.style.left = left + 'px'//登录弹窗在屏幕中的位置
            obj.style.top = top + 'px';
      
        }
      
        function hide(obj) {
            //点击差号时,登录弹窗消失,遮罩层消失
            obj.style.display = 'none';
            screen.style.display = 'none';
        }
      
        close[0].addEventListener("click"function () {
            hide(login)
        }, false);
        logins[0].addEventListener("click"function () {
            show(login)
        }, false);
      
    }

    三.效果图展示

    初始页面

    wKiom1dWH03TtMOKAA76TCKRZ8k780.png点击页面登录:弹出窗口页面如下:

    wKioL1dWIIjQKelaAALkcIJ6cZc836.png四.总结

       弹窗的是实现其实很简单,就是用display属性就可以解决,遮罩层也是控制其css属性,就可以实现。还有一点没有实现java培训,就是弹窗会随着鼠标进行移动,这个在后续的学习中继续完成。

  • 相关阅读:
    01_Struts2概述及环境搭建
    CSRF跨站请求伪造
    XSS跨站脚本攻击
    文件包含漏洞
    文件上传漏洞
    PHP常见代码执行后门函数
    SQL注入总结
    [转]Android PopupWindow的使用和分析
    [转] 基于XMPP协议的Android即时通信系
    [转]Android推送方案分析(MQTT/XMPP/GCM)
  • 原文地址:https://www.cnblogs.com/plan123/p/5566226.html
Copyright © 2020-2023  润新知