码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • JS-事件委托-阻止事件冒泡和阻止默认行为-滚动事件-加载事件-元素尺寸位置


    1.事件委托

    2.阻止事件冒泡和阻止默认行为

    3.滚动事件

    4.加载事件

    5.元素尺寸和位置

    offset 家族

    client 家族

    scroll 家族


    1.事件委托

    • 后代元素把事件委托给祖先元素,但是必须要明确是哪个后代
    • ul > li
    1. 新添加的元素事件不容易添加

    2. 事件委托能提升代码的性能

    1. let ulEl = document.querySelector("ul");
    2. ulEl.addEventListener("click", function (ev) {
    3. // 点击 ul 的徒子徒孙都会触发 ul 的点击事件
    4. if (ev.target.classList.xxx) {
    5. // 执行相应逻辑;
    6. }
    7. });

    2.阻止事件冒泡和阻止默认行为

    阻止冒泡是就让事件不再从子级向父级【传播】

    在事件回调函数中通过 ev.stopPropagation()

    一些标签自带了某些功能,比较典型的两个:a 标签 和 form 标签

    事件回调中的 ev.preventDefault()

    扩展:如果在 a 中看到了 <a href="javascript: ;">删除</a>
               含义是不想让 a 去跳转

    3.滚动事件

    scroll 事件与 click input change keyup 等,没有什么本质上的区别。

    • scroll 是在【页面】或【盒子】发生滚动的时候被触发
    • 页面的 document.addEventListener('scroll', function ( ) { })
    • 盒子的 盒子DOM.addEventListener('scroll', function ( ) { })
    • 注:当滚动事件发生时,一般是给某个父盒子进行监听。

    4.加载事件

    load 事件与 click input change keyup 等,没有什么本质上的区别。

    • 页面的 load 事件是指页面加载完毕(页面全部标签都生成了)后才去触发
    window.addEventListener("load", function () {});
    • 注:load 是指页面的【资源】完全加载完毕,如外部引入的 css 图片、字体等完成下载完成后才会执行。

    5.元素尺寸和位置

    offset 家族

    offsetWidth、offsetHeight 大小的确定 width + padding + border

    offsetLeft、offsetTop 位置的确定与定位有关(参照谁进行定位,位置就参照谁)

    • 如果盒子的所有祖先都没有定位,那么参照页面

    client 家族

    clientWidth、clienttHeight 大小的确定 width + padding - 滚动条宽度

    clientLeft、clientTop 实际就是边框的宽度

    scroll 家族

    只有盒子或页面发生滚动时它才有意义,如果没有滚动我们永远不会使用它。

    • scrollWidth、scrollHeight 大小的确定取决滚动内容的大小

    • scrollTop、scrollLeft 是指页面或盒子滚动的距离

  • 相关阅读:
    02Java线程模型
    Java中mybatis的Mpper代理开发的详细使用步骤
    jupyter环境配置
    一个非常简单用.NET操作RabbitMQ的方法
    维也纳酒店天津静海静文路店用心打造特色、优质睡眠空间
    微服务之Nacos注册管理
    20种富含维生素A的食物盘点,赶紧保存收藏!
    React组件之间的通信方式总结(下)
    韩媒表示Do Kwon疑每月通过LUNA2.0获310万美元质押收益
    flash-linear-attention CUDA算子成功实现(但限制极多。。)
  • 原文地址:https://blog.csdn.net/m0_62181310/article/details/125522955
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号