DOM事件练习 I

Posted jjzz1234

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DOM事件练习 I相关的知识,希望对你有一定的参考价值。

目录

input框动态显示事件

技术图片
 1 <head>
 2     <meta charset="UTF-8">
 3     <title>动态显示时间</title>
 4     <style>
 5         inputwidth:200px;
 6     </style>
 7  </head>
 8  <body>
 9  <input type="text" id="time">
10  <button id="switch">开始</button>
11  </body>
12  ?
13  <script>
14     var btn = document.getElementById(switch);
15     btn.onclick = function () 
16         switch (this.innerText) 
17             case 开始:
18                 this.innerText = 停止;
19                 timer1 = setInterval(update,1000);
20                 break;
21             case 停止:
22                 this.innerText = 开始;
23                 clearInterval(timer1);
24                 break;
25         
26     ;
27     function update() 
28         var t = document.getElementById(time);
29         var dt = new Date();
30         t.value = dt.toLocaleString();
31     
32  </script>
input框动态显示事件

红绿灯

技术图片
 1 <head>
 2     <meta charset="UTF-8">
 3     <title>事件-红绿灯</title>
 4     <style>
 5         .fadisplay: inline-block; padding: 5px;border-radius: 10px;border-color: darkgray;border-style: solid
 6         .div0width:100px;height:100px;border-radius: 50px; float: left;
 7             border-color: white;background-color: gray;
 8             display: inline-block;margin: 0;
 9         .div2background-color: green;
10         .div1background-color: red;
11         .div3background-color: yellow;
12     </style>
13  </head>
14  <body>
15  <div class="fa">
16     <div id="d0" class="div0 div1"></div>
17     <div id="d1" class="div0"></div>
18     <div id="d2" class="div0"></div>
19  </div>
20  ?
21  <script>
22  ?
23     function change()
24     
25         var tem = document.getElementsByClassName(div0);
26         if (tem[0].classList.contains(div1))
27         
28             tem[0].classList.remove(div1);
29             tem[1].classList.add(div2);
30         
31         else if (tem[1].classList.contains(div2))
32         
33             tem[1].classList.remove(div2);
34             tem[2].classList.add(div3);
35         
36         else if (tem[2].classList.contains(div3))
37         
38             tem[2].classList.remove(div3);
39             tem[0].classList.add(div1);
40         
41  ?
42     
43     setInterval(change,1000);
44  ?
45  </script>
46  </body>
红绿灯模拟

顶部广告栏关闭

技术图片
 1 <head>
 2     <meta charset="UTF-8">
 3     <title>顶部广告关闭</title>
 4     <style>
 5         bodymargin:0 ;
 6         .ad  position:fixed ; top:0; width: 100%; height: 100px;
 7             background-color: darkblue;opacity: 0.5
 8         .ad_contentposition: fixed;top:0; padding:20px;color: #53ff09
 9         #closeposition: fixed;top: 0; right: 0; background-color: lightyellow;
10                 height: 20px;width:20px;text-align:center; line-height: 20px;font-size:30px
11         .contentheight: 1000px;background-color: gray
12     </style>
13  </head>
14  <body>
15     <div class="ad" id="ad">
16         <div class="ad_content">
17         LOL新赛季即将开启,敬请期待
18         </div>
19         <div id="close">
20             x
21         </div>
22     </div>
23  ?
24     <div class="content">
25         详情请关注LOL世界锦标赛官方微博
26         详情请关注LOL世界锦标赛官方微博
27         详情请关注LOL世界锦标赛官方微博
28         详情请关注LOL世界锦标赛官方微博
29         详情请关注LOL世界锦标赛官方微博
30         详情请关注LOL世界锦标赛官方微博
31         详情请关注LOL世界锦标赛官方微博
32         详情请关注LOL世界锦标赛官方微博
33         详情请关注LOL世界锦标赛官方微博
34         详情请关注LOL世界锦标赛官方微博
35         详情请关注LOL世界锦标赛官方微博
36         详情请关注LOL世界锦标赛官方微博
37     </div>
38  </body>
39  <script>
40     var closebtn = document.getElementById(close);
41     closebtn.onclick = function () 
42         var ad= document.getElementById(ad);
43         ad.style.display = none;
44     
45  </script>
顶部广告

鼠标悬停IMG上时,更换另一张图片

技术图片
 1 //需求:鼠标放到img上,更换为另一张图片,也就是修改路径(src的值)。
 2             //步骤:
 3             //1.获取事件源
 4             //2.绑定事件
 5             //3.书写事件驱动程序
 6     
 7  <body>
 8  <img src="1.jpg" id="box" style="cursor: pointer;border: 1px solid #ccc;" >
 9  </body>
10  <script>
11     var img = document.getElementById(box);
12     img.onmouseover = function () 
13         img.src = 2.jpg;
14     ;
15     img.onmouseout = function () 
16         img.src = 1.jpg
17     ;
18  </script>
鼠标悬停更换图片

悬浮框自动出现

技术图片
 1 <head>
 2     <meta charset="UTF-8">
 3     <title>自动出现</title>
 4     <style>
 5         .d1width:70px; height:25px;background-color: #cccccc;position: fixed;
 6             bottom: 50px;right: 50px;text-align: center;line-height: 25px;border-radius: 5px;
 7         .d2display: none
 8         .a1text-decoration: none; color: #ff6700
 9     </style>
10  </head>
11  <body>
12  <div style="width: 100% ; height: 2000px;background-color: gray"></div>
13  <div class="d1 d2" id="d1"><a class="a1" id="a1" href="#">回到顶部</a></div>
14  </body>
15  <script>
16  ?
17     var sl = document.getElementById(d1);
18         window.onscroll = function () 
19             console.log(document.documentElement.scrollTop);
20             if (document.documentElement.scrollTop>700)
21                 sl.classList.remove(d2);
22             
23             else  sl.classList.add(d2); 
24         ;
25  ?
26  </script>
27  ?
28  // 行内实现
29  <body>
30  <div style="height: 4000px;width:20px;background-color: #ff6700"></div>
31  <p><a id="a1" style="position: fixed; bottom: 200px; z-index: 100; background-color: gray; right: 100px; color: white; display: block; padding: 5px; border-radius: 5px; text-decoration: none;" href="#">回到顶部</a></p>
32  ?
33  </body>
34  <script>
35         var ab= document.getElementById(a1);
36         window.onscroll = function () 
37             console.log(document.documentElement.scrollTop);
38             console.log(ab.style.display);
39             if (document.documentElement.scrollTop>700)
40                 ab.style.display = block;
41             
42             else  ab.style.display = none; 
43         ;
44  </script>
45  </html>
悬浮框自动出现

模态框案例

需求:打开网页时有一个普通的按钮,点击当前按钮显示一个背景图,中心并弹出一个弹出框,点击X的时候会关闭当前的模态框。

技术图片
 1 <!DOCTYPE html>
 2  <html lang="zh-ch">
 3  <head>
 4     <meta charset="UTF-8">
 5     <title>模态框</title>
 6     <style>
 7         *margin:0;padding :0;
 8         html,bodyheight: 100%;
 9         #boxwidth:100%;height:100%;background: rgba(0,0,0,.3);
10         #contentposition: relative;top:150px;width:400px;height: 200px;
11                   line-height: 200px;text-align: center;
12                   color: red; background-color: #fff;margin:auto; 
13         #span1position:absolute;background-color: red;top: 0 ;right:0;width: 30px;
14                 height: 30px;text-align: center;color:#fff;line-height: 30px;
15     </style>
16  </head>
17  <body>
18  <button id="btn">弹出</button>
19  </body>
20  <script type="text/javascript">
21     //获取dom元素:1获取事件源
22     var oBtn = document.getElementById(btn);
23     //创建弹出模态框的相关dom对象
24     var oDiv = document.createElement(div);
25     var oP = document.createElement(p);
26     var oSpan = document.createElement(span);
27  ?
28     //设置属性
29     oDiv.id = box;
30     oP.id = content;
31     oP.innerHTML=模态框弹出显示的内容;
32     oSpan.innerText = X;
33     oSpan.id = span1;
34  ?
35     //追加元素
36     oDiv.appendChild(oP);
37     oP.appendChild(oSpan);
38  ?
39     //设置点击弹窗按钮 弹出模态框
40     oBtn.onclick = function () 
41         this.parentNode.insertBefore(oDiv,oBtn);
42     ;
43  ?
44     //设置关闭按钮,关闭模态框
45     oSpan.onclick = function () 
46         oDiv.parentNode.removeChild(oDiv)
47     
48  </script>
49  </html>
模态框

回到顶部

以上是关于DOM事件练习 I的主要内容,如果未能解决你的问题,请参考以下文章

web前端练习28----Dom4,事件(事件对象,事件冒泡,事件委派,事件传播,事件绑定,事件移除及案例练习)

JavaScript DOM事件进阶及相关练习

DOM练习小记--简单的拼单词游戏

JS事件练习题

关于vue.js中事件处理器的练习

JS进阶练习