【JavaScript】28_DOM编程:间接修改css样式与事件对象,事件的冒泡

115 阅读2分钟

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第30天,点击查看活动详情

16、间接修改css样式

除了直接修改样式外,也可以通过修改class属性来间接的修改样式

通过class修改样式的好处:

  1. 可以一次性修改多个样式
  2. 对JS和CSS进行解耦

元素.classList

是一个对象,对象中提供了对当前元素的类的各种操作方法

元素.classList.add() :向元素中添加一个或多个class

元素.classList.remove(): 移除元素中的一个或多个class

元素.classList.toggle() :切换元素中的class

元素.classList.replace(): 替换class

元素.classList.contains() :检查class

     <style>
         .box1 {
             width: 200px;
             height: 200px;
             background-color: #bfa;
         }
 ​
 ​
         .box2{
             background-color: yellow;
             width: 300px;
             height: 500px;
             border: 10px greenyellow solid;
         }
     </style>
 </head>
 <body>
     <button id="btn">点我一下</button>
     <hr>
     <div class="box1 box3 box4"></div>
 ​
     <script>
         //点击按钮后,修改box1的宽度
         const btn = document.getElementById("btn")
         const box1 = document.querySelector(".box1")
 ​
         btn.onclick = function(){
             //除了直接修改样式外,也可以通过修改class属性来间接的修改样式
             // box1.className += 'box2'
 ​
             // box1.classList.add('box2','box3','box4')
             // box1.classList.add('box1')
 ​
             // box1.classList.remove('box2')
             box1.classList.toggle('box2')
             // box1.classList.replace('box2')
 ​
             let result = box1.classList.contains('box3')
             console.log(result)
         }
     </script>
 </body>

image-20221219210908175

17、事件对象

event 事件

  • 事件对象

    • 事件对象是有浏览器在事件触发时所创建的对象, 这个对象中封装了事件相关的各种信息
    • 通过事件对象可以获取到事件的详细信息 比如:鼠标的坐标、键盘的按键..
    • 浏览器在创建事件对象后,会将事件对象作为响应函数的参数传递, 所以我们可以在事件的回调函数中定义一个形参来接收事件对象
 <head>
     <meta charset="UTF-8">
     <meta http-equiv="X-UA-Compatible" content="IE=edge">
     <meta name="viewport" content="width=device-width, initial-scale=1.0">
     <title>Document</title>
     <style>
         #box1 {
             width: 300px;
             height: 300px;
             border: 10px greenyellow solid;
         }
     </style>
 </head>
 <body>
     <div id="box1"></div>
 ​
     <script>
         const box1 = document.getElementById("box1")
 ​
         box1.onmousemove = event => {
             console.log(event)
         }
 ​
         box1.addEventListener("mousemove",event => {
             console.log(event.clientX,event.clientY)
             box1.textContent = event.clientX + ',' + event.clientYs
         })
     </script>
 </body>

18、事件的冒泡

在DOM中存在着多种不同类型的事件对象

多种事件对象有一个共同的祖先 Event

  • event.target 触发事件的对象
  • event.currentTarget 绑定事件的对象(同this)
  • event.stopPropagation() 停止事件的传导
  • event.preventDefault() 取消默认行为

事件的冒泡(bubble)

  • 事件的冒泡就是指事件的向上传到
  • 当元素上的某个事件被触发后,其祖先元素上的相同事件也会同时被触发
  • 冒泡的存在大大的简化了代码的编写,但是在一些场景下我们并不希望冒泡存在 不希望事件冒泡时,可以通过事件对象来取消冒泡

在事件的响应函数中:

event.target :

表示的是触发事件的对象

this 绑定事件的对象

event.stopPropagation()

取消事件的传导

 <head>
     <meta charset="UTF-8">
     <meta http-equiv="X-UA-Compatible" content="IE=edge">
     <meta name="viewport" content="width=device-width, initial-scale=1.0">
     <title>Document</title>
     <style>
         #box1 {
             width: 300px;
             height: 300px;
             background-color: greenyellow;
         }
 ​
         #box2 {
             width: 250px;
             height: 250px;
             background-color: #ff0;
         }
 ​
         #box3 {
             width: 200px;
             height: 200px;
             background-color: orange;
         }
     </style>
 </head>
 <body>
     <div id="box1">
         <div id="box2">
             <div id="box3"></div>
         </div>
     </div>
 ​
     <a id="chao" href="https://lilichao.com">超链接</a>
 ​
     <script>
             const box1 = document.getElementById("box1")
             const box2 = document.getElementById("box2")
             const box3 = document.getElementById("box3")
             const chao = document.getElementById("chao")
 ​
             chao.addEventListener('click',(event)  =>{
                 event.preventDefault();
                 alert('被点了一下')
             })
 ​
             box1.addEventListener('click',function (event){
                 alert(event)
                 console.log(event.target)//event.target 表示的是触发事件的对象
                 console.log(this)//this 绑定事件的对象
                 console.log(event.currentTarget)
 ​
                 alert("hello 我是box1")
             })
 ​
             box2.addEventListener('click',function(event){
                 event.stopPropagation()
                 alert('我是box2')
             })
 ​
             box3.addEventListener('click',function(event){
                 event.stopPropagation()//取消事件的传导
                 alert('我是box3')
             })
     </script>
 </body>