首页 > 其他分享 >第十二天笔记 事件相关

第十二天笔记 事件相关

时间:2023-02-21 19:33:05浏览次数:44  
标签:function 第十二天 元素 笔记 事件 var console document

第十二天笔记

 

事件流的传播流程

事件流的传播有三个阶段

  • 捕获阶段

    从最外层找到对应的事件执行的元素

  • 目标阶段

    找到这个元素 执行对应的事件

  • 冒泡阶段

    逐层向上冒泡执行对应的事件

image-20230221113923176

<div onclick="alert(2)">
       <button onclick="alert(1)"></button>
   </div>
   <script>
       document.body.onclick=function(){
           console.log(3);
      }
   </script>

以上的这个示例 会从button 开始不断向上执行 直到window停止 所以对应的执行结果为1,2,3

如果我们不想触发对应的外层的事件 只是想触发本身的事件 那么我们就需要禁止事件冒泡了

禁止事件冒泡的处理

stopPropagation

document.body.onclick=function(){
           console.log(3);
          e.stopPropagation()
      }

cancelBubble(event对象的属性)

  console.log(e.cancelBubble);// 阻止冒泡 默认值为false
           console.log(e.returnValue);// 返回的value值 返回的是true 可以走 false不可以走 默认为true

兼容写法

e.stopPropagation()?e.stopPropagation():e.cancelBubble=true

事件流的两种模式

  • 冒泡模式(从里到外 逐层执行对应的事件)

    冒泡模式是常用的模式,他现在默认设计的就是冒泡模式

  • 捕获模式(从外到里 逐层执行对应的事件)

    捕获模式是火狐提出来的模式,ie对应的6,7,8 不支持。 现在的模式一般很少使用捕获模式

默认行为

元素标签尤其默认行为( a标签会跳转页面),对应的事件也有其默认行为(contextmeun 会出现对应的菜单栏)

禁止默认行为

  • preventDefault

  • returnValue event的属性

  • return false 一般不用一定要放在最后

document.querySelector('a').onclick = function (e) {
           e = e || window.event
           console.log('点击');
           // a标签会默认刷新页面 为了禁止这个操作 那么我们可以禁止他的默认行为
           e.defaultPrevented // 是否阻止了默认行为 只读
           // e.preventDefault()// preventDefault 阻止默认行为
           
           e.returnValue=false// 兼容ie的
           // 兼容写法
           e.preventDefault()? e.preventDefault():e.returnValue=false
      }
       // 对应的右键点击
       document.oncontextmenu=function(e){
           console.log('右键点击');
           // e.preventDefault()? e.preventDefault():e.returnValue=false
           return false // 一定要在最后
      }

示例

右键点击出现对应的菜单栏 这个菜单栏自定义(前进功能 后退功能 刷新功能 换肤 打印·)

// 右键点击出现对应的菜单栏 这个菜单栏自定义(前进功能 后退功能 刷新功能 换肤 打印·)
       document.oncontextmenu = function (e) {
           // 渲染ul
           document.body.innerHTML = `
           <ul class="box">
               <li>前进</li>
               <li>后退</li>
               <li>刷新</li>
               <li>换肤</li>
               <li>打印</li>
           </ul>
           `

           // 获取元素
           var box = document.querySelector('.box')
           var li = document.querySelectorAll('li')

           // 调整box的位置
           box.style.top = e.pageY + 'px'
           box.style.left = e.pageX + 'px'

           // 取消默认事件
           e.preventDefault()


           // li委托事件 鼠标移入变色
           box.onmouseover=function(e){
               // console.log(111);// 测试
               if(e.target.nodeName=='LI'){
                   for(var l of box.children){
                       l.style.backgroundColor='#fff'
                  }
                   // console.log(e.target);// 测试
                   e.target.style.backgroundColor='#ccc'
              }
          }

           // 给li标签添加事件
           li[0].onclick = function (e) {
               // console.log(111);// 测试
               history.forward()
          }
           li[1].onclick = function () {
               history.back()
          }
           li[2].onclick = function () {
               location.reload()
          }
           li[3].onclick = function () {
               changeSkin(document.body)
          }
           li[4].onclick = function () {
               window.print()
          }
           // 点击取消右键框
           box.onclick= function(e){
               if(e.target.nodeName=='LI'){
                   this.innerHTML=''
              }
          }
      }
       // 换色代码
       function changeSkin(element) {
           var r = Math.random() * 255
           var g = Math.random() * 255
           var b = Math.random() * 255
           element.style.background = `rgba(${r},${g},${b})`
      }

事件监听器

eventListener 他是一个标准的观察者模式,它是通过对应的监听器来监听事件的触发和执行

主要有两个方法

  • addEventListener 添加事件监听器

    传入对应的事件名及处理函数 以及对应的是否冒泡

    注意事项

    addEventListener 可以在一个事件中传入多个处理函数

    EventListenter 支持自定义事件名

    onclick 赋值不支持多个处理函数

  • removeEventListener 移除事件监听器

    移除对应添加的事件监听器,传入事件名、处理函数、是否冒泡 每个都必须和添加的事件监听器一致 不然不能被移除

    注意事项

    如果添加事件监听器的时候传入处理函数为匿名函数 那么不能被移除

拖拽

原理

  • 给对应需要拖拽的元素添加按下事件

  • 再按下事件内添加对应的移动事件

  • 再按下事件内添加对应的弹起事件 在弹起事件中释放移动事件 释放弹起事件

基础拖拽

思路

  • 获取拖拽元素

  • 给拖拽元素添加按下事件 并记录按下的坐标

  • 给区间元素添加移动事件 并记录移动的坐标

  • 在区间元素的鼠标移动事件中设置对应的拖拽元素的坐标

  • 在document中添加鼠标弹起事件 并释放之前的移动事件及自身的弹起事件

区间拖拽

offset家族 (属于元素对象 element对象)

// offset家族
       // offsetParent 偏移的父元素
       // 获取inner
       var inner=document.querySelector('.inner')
       console.log(inner.offsetParent);// 找有定位的上层元素
       console.log(inner.offsetLeft);// 左偏移 不会计入父元素本身的margin值 但会计入padding值
       console.log(inner.offsetTop);// 右偏移
       console.log(inner.offsetWidth);// 偏移元素的宽度
       console.log(inner.offsetHight);

 

思路
  • 获取拖拽的元素

  • 给拖拽元素添加鼠标按下事件 并记录按下的坐标(在对应的盒子里的坐标)

  • 在按下事件内给区间元素添加鼠标移动事件 并记录每次移动的坐标

  • 在区间元素的鼠标移动事件中 获取对应的区间元素的位置 及 能够移动的距离 (区间元素的宽/高度 - 自身的宽/高度)

  • 设置移动元素处在区间元素的位置 移动位置在父元素的坐标 = 页面的位置 - 父元素离页面的位置 - 鼠标点击的位置

  • 对应坐标位置进行区间判断 小于0的时候值应该设置为0 大于能够移动的距离设为最大的距离

  • 在按下事件内在document中添加鼠标弹起事件 并释放之前的移动事件及自身的弹起事件

<div>
   <button>
      移动的按钮
   </button>
</div>
<script>
   var box = document.querySelector('div')
   var button = document.querySelector('button')
   button.onmousedown = function(e){
       e = e || window.event
       //记录在而盒子上的坐标
       var x = e.offsetX
       var y = e.offsetY
       //在box中移动
       box.onmousemove = function(e){
           e = e || window.event
           //获取区间元素的位置
           var bx = this.offsetLeft
           var by = this.offsetTop
           //获取能够移动的最大距离
           var maxX =  this.offsetWidth - button.offsetWidth
           var maxY =  this.offsetHeight - button.offsetHeight
           //移动位置在父元素的坐标 = 页面的位置 - 父元素离页面的位置 - 鼠标点击的位置
           var targetX = e.pageX - bx - x
           var targetY = e.pageY - by - y
           //进行区间判断
           if(targetX < 0){
               targetX = 0
          }
           if(targetY < 0){
               targetY = 0
          }
           if(targetX > maxX){
               targetX = maxX
          }
           if(targetY > maxY){
               targetY = maxY
          }
           button.style.left = targetX + 'px'
           button.style.top = targetY + 'px'
      }
       document.onmouseup = function(){
           box.onmousemove = document.onmouseup  = null
      }
  }
</script>
封装一个方法找盒子到页面的距离
function getBoxToPageDistance(element){
var distance = {
x:0,
y:0
} //距离对象
while(element.offsetParent){ //找到body就停止
distance.x += element.offsetLeft
distance.y += element.offsetTop
element = element.offsetParent
}
return distance
}
 

标签:function,第十二天,元素,笔记,事件,var,console,document
From: https://www.cnblogs.com/balloontrue/p/17142143.html

相关文章

  • 【线性代数复习笔记】矩阵特征值,特征向量,相似对角化与实对称矩阵
    【线性代数复习笔记】矩阵特征值,特征向量,相似对角化与实对称矩阵线代好难-_-特征值与特征向量:1.求解特征值与特征向量:​ 先计算特征多项式f(ʎ)=|ʎI-A|,求出根,再根据......
  • 阿里云-云原生技术公开课的笔记之二 Job & CronJobs、DaemonSet
      第一个是restartPolicy,在Job里面我们可以设置Never、OnFailure、Always这三种重试策略。在希望Job需要重新运行的时候,我们可以用Never;希望在失败的时候再......
  • TypeScript 入门自学笔记 — 接口的使用(六)
    目录一.函数接口参数二.函数类型接口三.函数混合类型四.对象接口(最常用)确定属性可选属性任意属性只读属性可索引接口索引访问符类接口接口继承构造函数类型type和inter......
  • Vue 学习笔记-入门(1)
    Vue入门简述​Vue(读音/vjuː/,类似于view)是一套用于构建用户界面的渐进式JavaScript框架。[5]与其它大型框架不同的是,Vue被设计为可以自底向上逐层应用。Vue的核......
  • PMP学习笔记《第八章 项目成本管理》
    质量管理的各种名言警句:1、等级低不一定是个问题,质量未达到要求肯定是个问题;2、PDCA循环由休哈特定义,戴明改进并完善PDCA环(14条原则)即持续改进;预防胜于检查3、朱兰:质......
  • 如何在手机上做高质量的读书笔记
    你有没有这样的感受,自己想要在写作上有所建树,但是每天只进行阅读,而没有时间做读书笔记。这样一篇文章阅读结束了,不知道文章的中心思想有哪些;一本书读完之后,也是只知道个大......
  • 随堂笔记11-spring之配置类解析
    spring之配置类解析启动spring时,需要传入一个appconfig.class给applicationContext,然后被封装为beanDefinition,这种beanDefinition称之为配置类beanDefinitionConfigu......
  • 笔记即思维
    很多人会纠结于哪个笔记软件比较好,对比各个软件的功能。其实并没有必要,他们只是代表了各个设计者不同的思维。比如:印象笔记,是按照传统的笔记本,多个笔记本形成组,就像我们......
  • linux常用命令笔记
    1、kill指定条件的进程ps -ef | grepsomeone| awk '{ print $2 }' | xargs kill -92、遍历删除当前目录下指定名称的文件(-typef来指定是删除文件,-type......
  • 汇编笔记
                                    表A-3常见的x86指令指令描述数据传输❶movdst,src......