Web APIs 2 事件

Web APIs 2 事件

  • 事件监听
      • 案例:广告关闭
      • 案例:随机问答
  • 事件监听版本
  • 事件类型
      • 案例:轮播图完整
      • 焦点事件
      • 键盘事件
      • 输入事件
      • 案例:评论字数统计
  • 事件对象
      • 获取事件对象
      • 事件对象常用属性
      • 案例:评论回车发布
  • 环境对象this
  • 回调函数
  • 综合案例
      • tab栏切换
      • 全选反选案例

事件监听

  • 什么是事件?

事件是在编程时系统内发生的动作或者发生的事情

比如用户在网页上单击一个按钮

  • 什么是事件监听?

就是让程序检测是否有事件产生,一旦有事件触发,就立即调用一个函数做出响应,也称为 绑定事件或者注册事件

比如鼠标经过显示下拉菜单,比如点击可以播放轮播图等等

  • 语法
元素对象.addEventListener('事件类型', 要执行的函数)
  • 事件监听三要素

事件源: 那个dom元素被事件触发了,要获取dom元素

事件类型: 用什么方式触发,比如鼠标单击 click、鼠标经过 mouseover 等

事件调用的函数: 要做什么事

在这里插入图片描述

// 事件源 按钮
const btn = document.querySelector('button')

// 事件类型
// 事件处理程序
btn.addEventListener('click', function() {
alert('hi')
})

案例:广告关闭

点击关闭广告,刷新之后广告又出现

<body>
  <div class="box">
    我是广告
    <div class="box1">X</div>
  </div>
  <script>
    // 1. 获取事件源
    const box1 = document.querySelector('.box1')
    //  关闭的是大盒子
    const box = document.querySelector('.box')
    // 2. 事件侦听
    box1.addEventListener('click', function () {
      box.style.display = 'none'
    })
  </script>
</body>

案例:随机问答

业务: 点击开始后,随机闪现所有人的名字,点击结束,停止在一个人名,并删除这个元素.

在这里插入图片描述

业务分析:

① 点击开始按钮随机抽取数组的一个数据,放到页面中

② 点击结束按钮删除数组当前抽取的一个数据

③ 当抽取到最后一个数据的时候,两个按钮同时禁用(写点开始里面,只剩最后一个数据不用抽了)

核心: 利用定时器快速展示,停止定时器结束展示

<body>
    <h2>随机点名</h2>
    <div class="box">
        <span>名字是:</span>
        <div class="qs">这里显示姓名</div>
    </div>
    <div class="btns">
        <button class="start">开始</button>
        <button class="end">结束</button>
    </div>

    <script>
        // 数据数组
        const arr = ['马超', '黄忠', '赵云', '关羽', '张飞']

        // 业务1 开始按钮模块
        // 点击开始按钮之后,通过随机数随机选取数组中的名字,并显示在网页中
        let timer = 0
        const start = document.querySelector('.start')
        const qs = document.querySelector('.qs')
        let random = 0
        start.addEventListener('click',function() {
          // 每次点击按钮都会有一个新的定时器,点击结束按钮只会关闭最后一个定时器
          timer = setInterval(function() {
            random = Math.floor(Math.random()*arr.length)
            // arr[random]
            qs.innerHTML = arr[random]
          }, 50) 

          if(arr.length === 1) {
            start.disabled = end.disabled = true
          }
        })

        // 业务2 结束按钮模块
        const end = document.querySelector('.end')
        end.addEventListener('click',function() {
          clearInterval(timer)
          arr.splice(random,1)
        })
    </script>
</body>

垃圾回收机制:函数执行结束之后不再使用这个变量,会自动删除

//这段代码不会报错,因为垃圾回收机制
//html: <button>btn</button>

//script
const btn = document.querySelector('button')
btn.addEventListener('click',function() {
  const num = Math.random()
  console.log(num)
})
//这段代码不会报错,因为作用域不一样
const num = 10

const btn = document.querySelector('button')
btn.addEventListener('click',function() {
  const num = Math.random()
  console.log(num)
})

事件监听版本

DOM Level 0

事件源.on事件 = function() { }

DOM Level 2

事件源.addEventListener(事件, 事件处理函数)

区别:

on方式会被覆盖,addEventListener方式可绑定多次,拥有事件更多特性,推荐使用

发展史:

DOM L0 :是 DOM 的发展的第一个版本; L:level

DOM L1:DOM级别1 于1998年10月1日成为W3C推荐标准

DOM L2:使用addEventListener注册事件

DOM L3: DOM3级事件模块在DOM2级事件的基础上重新定义了这些事件,也添加了一些新事件类型

事件类型

  • 事件监听三要素:事件源、事件类型、事件调用的函数

在这里插入图片描述

//html 
//<div></div>

//css
div {
	width:200px;
	height:200px;
	background-color:pink;
}

//javascript
const div = document.querySelector('div')
//鼠标经过
div.addEventListener('mouseenter',function() {
	console.log('轻轻的我来了')
})
//鼠标离开
div.addEventListener('mouseleave',function() {
	console.log('轻轻的我走了')
})

案例:轮播图完整

需求:当点击左右的按钮,可以切换轮播图

分析:

①:右侧按钮点击,变量++,如果大于等于8,则复原0

②:左侧按钮点击,变量–,如果小于0,则复原最后一张

③:鼠标经过暂停定时器

④:鼠标离开开启定时器

业务分析:左侧按钮、右侧按钮、鼠标经过、自动播放

焦点事件

<body>
  <input type="text">
</body>
<script>
  const input = document.querySelector('text')
  input.addEventListener('focus',function() {
    console.log('haha');
  })
</script>
  • 小米搜索框案例

需求:当表单得到焦点,显示下拉菜单,失去焦点隐藏下来菜单

<!DOCTYPE html>
<html lang="en">

<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>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        ul {
            list-style: none;
            display: none;
        }

        .mi {
            position: relative;
            width: 223px;
            margin: 100px auto;
        }

        .mi input {
            width: 223px;
            height: 48px;
            padding: 0 10px;
            font-size: 14px;
            line-height: 48px;
            border: 1px solid #e0e0e0;
            outline: none;
        }

        .mi .search {
            border: 1px solid #ff6700;
        }

        .result-list {
            position: absolute;
            left: 0;
            top: 48px;
            width: 223px;
            border: 1px solid #ff6700;
            border-top: 0;
            background: #fff;
        }

        .result-list a {
            display: block;
            padding: 6px 15px;
            font-size: 12px;
            color: #424242;
            text-decoration: none;
        }

        .result-list a:hover {
            background-color: #eee;
        }
    </style>

</head>

<body>
    <div class="mi">
        <input type="search" placeholder="小米笔记本">
        <ul class="result-list">
            <li><a href="#">全部商品</a></li>
            <li><a href="#">小米11</a></li>
            <li><a href="#">小米10S</a></li>
            <li><a href="#">小米笔记本</a></li>
            <li><a href="#">小米手机</a></li>
            <li><a href="#">黑鲨4</a></li>
            <li><a href="#">空调</a></li>
        </ul>
    </div>
    <script>
      //属性选择器
      const input = document.querySelector('[type=search]')
      const ul = document.querySelector('.result-list')

      input.addEventListener('focus', function() {
        ul.style.display = 'block'
        input.classList.add('search')
      })

      input.addEventListener('blur', function() {
        ul.style.display = 'none'
        input.classList.remove('search')
      })
    </script>
</body>

</html>

键盘事件

<input type="text">
<script>
const input = document.querySelector('input')

input.addEventListener('keydown', function() {
    console.log('键盘按下了')
})

input.addEventListener('keyup', function() {
    console.log('键盘抬起了')
})
</script>

输入事件

得到用户输入的内容通过input.value

<input type="text">
<script>
const input = document.querySelector('input')

input.addEventListener('input', function() {
    console.log('1111111111') //输入内容
    console.log(input.value)
})
</script>

案例:评论字数统计

需求:用户输入文字,可以计算用户输入的字数

分析:

①:判断用输入事件 input

②:不断取得文本框里面的字符长度, 文本域.value.length

③:把获得数字给下面文本框

代码 看下文的评论回车发布

focus伪类选择器:获得焦点

注:不使用 JS,使用 CSS 也可以实现

<body>
  <input type="text">
</body>
<style>
  input {
    width: 200px;
  }
  input:focus {
    /* 获得光标 */
    width: 300px;
  }
</style>

事件对象

  • 获取事件对象
  • 事件对象常用属性

事件对象是什么

也是个对象(属性 方法),这个对象里有事件触发时的相关信息

例如:鼠标点击事件中,事件对象就存了鼠标点在哪个位置等信息

使用场景

可以判断用户按下哪个键,比如按下回车键可以发布新闻(按下空格键就不能发)

可以判断鼠标点击了哪个元素,从而做相应的操作

事件对象在哪里?

在事件绑定的回调函数的第一个参数就是事件对象

获取事件对象

语法

  • 在事件绑定的回调函数的第一个参数就是事件对象

  • 一般命名为event、ev、e

元素.addEventListener('click', function(e) {
// 这里的e就是事件对象
})

例如:

// <button></button>
const btn = document.querySelector('btn')
btn.addEventListener('click', function() {
	console.log(e);
})

在这里插入图片描述

事件对象常用属性

部分常用属性

  • type: 获取当前的事件类型

  • clientX/clientY: 获取光标相对于浏览器可见窗口左上角的位置

  • offsetX/offsetY: 获取光标相对于当前DOM元素左上角的位置

  • key: 用户按下的键盘键的值。现在不提倡使用keyCode 已经废除

<body>
  <!-- 回车键触发案例 -->
  <input type="text">
</body>
<script>
  const btn = document.querySelector('button')
  btn.addEventListener('click', function(e) {
    console.log(e);
  })

  const input = document.querySelector('input')
  input.addEventListener('keyup',function(e) {
    // console.log(e.key);
    if(e.key === 'Enter') {
      console.log('我按下了回车键');
    }
  })
</script>

案例:评论回车发布

需求:按下回车键盘,可以发布信息

分析:

①:用到按下键盘事件 keydown 或者 keyup 都可以

②:如果用户按下的是回车键盘,则发布信息

③:让留言信息模块显示,把拿到的数据渲染到对应标签内部

补一个trim方法

只清除左右的空格

  const str = '   pink  '
  console.log(str)  // '   pink  '
  console(str.trim()) // 'pink'

代码:

在这里插入图片描述

<body>
  <div class="wrapper">
    <i class="avatar"></i>
    <textarea id="tx" placeholder="发一条友善的评论" rows="2" maxlength="200"></textarea>
    <button>发布</button>
  </div>
  <div class="wrapper">
    <span class="total">0/200字</span>
  </div>

  <div class="list">
    <div class="item" style="display: none;">
      <i class="avatar"></i>
      <div class="info">
        <p class="name">清风徐来</p>
        <p class="text">大家都辛苦啦,感谢各位大大的努力,能圆满完成真是太好了[笑哭][支持]</p>
        <p class="time">2022-10-10 20:29:21</p>
      </div>
    </div>
  </div>
</body>

<script>
  //文本域获得焦点:让total显示出来
  const tx = document.querySelector('#tx')
  const total = document.querySelector('.total')
  tx.addEventListener('focus', function() {
    total.style.opacity = 1
  })

  tx.addEventListener('blur', function() {
    total.style.opacity = 0
  })

  //检测用户输入
  tx.addEventListener('input', function() {
    total.innerHTML = `${tx.value.length}/200字`
  })

  //按下回车发布评论
  const item = document.querySelector('.item')
  const text = document.querySelector('.text')
  tx.addEventListener('keyup', function(e) {
    if(e.key === 'Enter') {
      if(tx.value.trim() !== '') {
        text.innerHTML = tx.value
        item.style.display = 'block'
      }
      tx.value='' //清空文本域
       //按下回车之后 字符统计复原
      total.innerHTML = '0/200字'
    }
  })

</script>

环境对象this

环境对象: 指的是函数内部特殊的变量 this ,它代表着当前函数运行时所处的环境

作用: 弄清楚this的指向,可以让我们代码更简洁

  • 函数的调用方式不同,this 指代的对象也不同

【谁调用, this 就是谁】 是判断 this 指向的粗略规则

  • 直接调用函数,其实相当于是 window.函数,所以 this 指代 window
 //每一个函数里面都有this
  function fn() {
    console.log(this); 
  }
  fn() // 相当于是 window.fn(),所以 this 指代 window
  const btn = document.querySelector('button')
  btn.addEventListener('click', function() {
    console.log(this); //指向button
  })

回调函数

如果将函数 A 做为参数传递给函数 B 时,我们称函数 A 为回调函数

简单理解: 当一个函数当做参数来传递给另外一个函数的时候,这个函数就是回调函数

在这里插入图片描述

过了一秒钟,回头调用函数 fn

每click一次,调用一次函数

综合案例

tab栏切换

选项卡切换

全选反选案例

用户点击大全选,所有的复选框全部选择

用户取消大全选,则所有复选框取消

用户选了所有的复选框之后,大全选自动选择

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/372133.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

电脑怎么扫描纸质文件?6步轻松完成扫描!

“由于工作的需要&#xff0c;我要将部分纸质文件扫描到电脑上&#xff0c;不知道应该怎么操作会更方便呢&#xff1f;希望大家给我出出主意。” 随着科技的进步&#xff0c;电脑已经成为了我们日常生活和工作中不可或缺的工具。除了传统的文字处理和数据处理&#xff0c;电脑还…

【漏洞库】O2OA系统

O2OA invoke 后台远程命令执行漏洞 CNVD-2020-18740 漏洞描述 O2OA是一款开源免费的企业及团队办公平台,提供门户管理、流程管理、信息管理、数据管理四大平台,集工作汇报、项目协作、移动OA、文档分享、流程审批、数据协作等众多功能,满足企业各类管理和协作需求。 O2OA系…

拍摄的视频怎么做二维码?视频在线转二维码的技巧

现在学校经常会将学生日常的拍摄的短片做成二维码之后展示给其他人&#xff0c;其他人可以通过扫描二维码来查看个人表现的视频&#xff0c;有些活动视频也会用视频二维码的方式来传播。那么视频二维码制作的方法及步骤是什么样的呢&#xff1f;下面就让小编通过本文来给大家介…

力扣 121. 买卖股票的最佳时机

题目来源&#xff1a;https://leetcode.cn/problems/best-time-to-buy-and-sell-stock/description/ 好久没写代码了&#xff0c;啥啥都忘了 C题解1&#xff1a;贪心算法。&#xff08;来源代码随想录&#xff09; 因为股票就买卖一次&#xff0c;那么贪心的想法很自然就是取…

读写锁ReentrantReadWriteLockStampLock详解

传送门&#xff1a;深入理解AQS独占锁之ReentrantLock源码分析 目录 读写锁介绍 ReentrantReadWriteLock介绍 ReentrantReadWriteLock的使用 应用场景 锁降级 读写锁设计思路 StampedLock介绍 StampedLock的使用 演示乐观读 在缓存中的应用 使用场景和注意事…

033-安全开发-JavaEE应用SQL预编译Filter过滤器Listener监听器访问控制

033-安全开发-JavaEE应用&SQL预编译&Filter过滤器&Listener监听器&访问控制 #知识点&#xff1a; 1、JavaEE-JDBC-SQL预编译 2、JavaEE-HTTP-Filter过滤器 3、JavaEE-对象域-Listen监听器 演示案例&#xff1a; ➢JavaEE-预编译-SQL ➢JavaEE-过滤器-Filter ➢…

python Cloudflare 批量关闭IPv6兼容性脚本

Cloudflare免费版控制台不给关IPv6&#xff0c;需要使用API关闭&#xff0c;先从我的个人资料里面申请API令牌&#xff0c;再执行脚本 import requests import jsonheaders {X-Auth-Email:cloudflare登入账户, #输入登入账户的邮箱X-Auth-Key: Global API Key, #输入上图申请…

计算机自顶向下 Wireshark labs——DNS

如本文第2.4节所述&#xff0c;域名系统(DNS)将主机名转换为IP地址&#xff0c;在互联网基础设施中发挥着关键作用。在本实验中&#xff0c;我们将仔细研究DNS的客户端。回想一下&#xff0c;客户端在DNS中的角色相对简单—客户端向其本地DNS服务器发送查询&#xff0c;并收到响…

探索设计模式的魅力:从单一继承到组合模式-软件设计的演变与未来

设计模式专栏&#xff1a;http://t.csdnimg.cn/nolNS 在面对层次结构和树状数据结构的软件设计任务时&#xff0c;我们如何优雅地处理单个对象与组合对象的一致性问题&#xff1f;组合模式&#xff08;Composite Pattern&#xff09;为此提供了一种简洁高效的解决方案。通过本…

使用 PyTorch 构建 NLP 聊天机器人

一、说明 聊天机器人提供自动对话&#xff0c;可以帮助用户完成任务或寻求信息。随着深度学习的最新进展&#xff0c;聊天机器人正变得越来越具有对话性和实用性。这个全面的教程将利用 PyTorch 和 Python 从头开始构建聊天机器人&#xff0c;涵盖模型架构、数据准备、训练循环…

【动态规划】【状态压缩】【2次选择】【广度搜索】1494. 并行课程 II

作者推荐 视频算法专题 本文涉及知识点 动态规划汇总 状态压缩 广度优先搜索 LeetCode1494. 并行课程 II 给你一个整数 n 表示某所大学里课程的数目&#xff0c;编号为 1 到 n &#xff0c;数组 relations 中&#xff0c; relations[i] [xi, yi] 表示一个先修课的关系&am…

nginx slice模块的使用和源码分析

文章目录 1. 为什么需要ngx_http_slice_module2. 配置指令3. 加载模块4. 源码分析4.1 指令分析4.2 模块初始化4.3 slice模块的上下文4.2 $slice_range字段值获取4.3 http header过滤处理4.4 http body过滤处理5 测试和验证 1. 为什么需要ngx_http_slice_module 顾名思义&#…

配置Jenkins自动构建打包项目

转载说明&#xff1a;如果您喜欢这篇文章并打算转载它&#xff0c;请私信作者取得授权。感谢您喜爱本文&#xff0c;请文明转载&#xff0c;谢谢。 需求说明 1、给A项目配置jenkins每2小时无条件自动构建一次&#xff0c;无论是否有代码提交。 2、给B项目配置jenkins每15分钟检…

FPGA高端项目:IMX327 MIPI 视频解码 USB3.0 UVC 输出,提供FPGA开发板+2套工程源码+技术支持

目录 1、前言免责声明 2、相关方案推荐我这里已有的 MIPI 编解码方案 3、本 MIPI CSI-RX IP 介绍4、个人 FPGA高端图像处理开发板简介5、详细设计方案设计原理框图IMX327 及其配置MIPI CSI RX图像 ISP 处理图像缓存UVC 时序USB3.0输出架构 6、vivado工程详解FPGA逻辑设计 7、工…

ChatGPT辅助编程,一次有益的尝试

如果大家想学习PCIe&#xff0c;搜索网上的信息&#xff0c;大概率会看到chinaaet上Felix的PCIe扫盲系列的博文 Felix-PCIe扫盲 每次看这个系列博文的时候&#xff0c;我都在想有没有什么方法可以把这个系列的博文都保存到一个pdf文件中&#xff0c;这样方便阅读。于是有了下…

异地办公必不可缺的远程控制软件,原理到底是什么?

目录 引言远程桌面连接软件的作用与重要性 基本概念与架构客户端-服务器模型网络通信协议 核心技术组件图形界面捕获与传输输入转发会话管理 性能优化策略带宽优化延迟优化 引言 远程桌面连接软件的作用与重要性 在当今这个高度数字化和网络化的时代&#xff0c;远程桌面连接软…

R语言学习case10:ggplot基础画图Parallel Coordinate Plot 平行坐标图

step1: 导入ggplot2库文件 library(ggplot2)step2&#xff1a;带入自带的iris数据集 iris <- datasets::irisstep3&#xff1a;查看数据信息 dim(iris)维度为 [150,5] head(iris)查看数据前6行的信息 step4&#xff1a;利用ggplot工具包绘图 plot5 <- ggparcoord(…

Linux目录:traceroute命令

目录 traceroute1、简介2、探测原理3、traceroute说明4、实例设置每跳探测数设置跳数探测包使用的基本UDP端口设置6789把对外发探测包的等待响应时间设置为3秒 总结 traceroute 1、简介 traceroute的主要功能是跟踪从IP网络发送到指定主机经过的网关的工具。它利用IP协议的生…

npm淘宝镜像源换新地址

新的淘宝npm镜像源地址&#xff1a;https://registry.npmmirror.com 切换新的镜像源 npm config set registry https://registry.npmmirror.com然后再执行以下操作查看是否成功 npm config list如果没安装过淘宝镜像源的&#xff0c;则直接安装 npm install -g cnpm --regi…

机器学习 - 梯度下降

场景 上一章学习了代价函数&#xff0c;在机器学习中&#xff0c;代价模型是用于衡量模型预测值与真实值之间的差异的函数。它是优化算法的核心&#xff0c;目标是通过调整模型的参数来最小化代价模型的值&#xff0c;从而使模型的预测结果更接近真实值。常见的代价模型是均方…