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培训,就是弹窗会随着鼠标进行移动,这个在后续的学习中继续完成。

原文地址:https://www.cnblogs.com/plan123/p/5566226.html