当前位置: 首页 > news >正文

APIs-day3

1.全选反选案例

<head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1.0"><title>练习</title><style>*{margin: 0;padding: 0;}table{margin: 100px auto;width: 500px;border: 1px solid #c0c0c0;border-collapse: collapse;text-align: center;border-spacing: 0;}th{background-color: #09c;color:#fff;font:bold 16px "微软雅黑";height: 24px;}td{padding: 10px;color:#404060;border:1px solid #d0d0d0;}.allcheck{width: 80px;}</style></head><body><table><tr><th class="allcheck"><input type="checkbox" name="" id="checkAll"><span class="all">全选</span></th><th>商品</th><th>商家</th><th>价格</th></tr><tr><td><input type="checkbox" name="check" class="ck"></td><td>小米手机</td><td>小米</td><td>¥1999</td></tr><tr><td><input type="checkbox" name="check" class="ck"></td><td>小米净水器</td><td>小米</td><td>¥4999</td></tr><tr><td><input type="checkbox" name="check" class="ck"></td><td>小米电视</td><td>小米</td><td>¥5999</td></tr></table><script>const allcheck=document.querySelector('#checkAll')const ck=document.querySelectorAll('.ck')allcheck.addEventListener('click',function(){for(let i=0;i<ck.length;i++){ck[i].checked=this.checked}})for(let i=0;i<ck.length;i++){ck[i].addEventListener('click',function(){allcheck.checked=document.querySelectorAll('.ck:checked').length===ck.length})}</script>
</body></html>

2.事件流

事件流是事件完整执行过程中的流动路径

捕获阶段:从父到子,DOM.addEventListener(事件类型,事件处理函数,是否使用捕获机制)

冒泡阶段:从子到父,当一个元素的事件被触发时,同样的事件会在该元素的所有祖先元素中依次被触发,(同名事件)

阻止冒泡:把事件限制在当前元素中,事件对象.stopPropagation() 冒泡和捕获都有效

L2 事件解绑:removeEventListener(事件类型,事件处理函数,【获取捕获或者冒泡阶段】)匿名函数不能解绑

L0事件解绑:btn.οnclick=null

鼠标经过事件:mouseover和mouseout有冒泡效果,mouseenter和mouseleave没有冒泡效果

3.事件委托

利用事件流特征解决一些开发需求的知识技巧

优点:减少注册次数,可以提高程序性能

原理:事件委托利用事件冒泡的特点,给父元素注册事件,当我们触发子元素时候,会冒泡到父元素身上,触发父元素事件。

实现:事件对象.target.tagName可以获得真正触发事件的元素

<body><ul><li>第1个孩子</li><li>第2个孩子</li><li>第3个孩子</li><li>第4个孩子</li><li>第5个孩子</li><p>我不要变色</p></ul><script>const ul = document.querySelector('ul')ul.addEventListener('click', function (e) {if(e.target.tagName==='LI'){e.target.style.color = 'red'}})</script></body>

使用事件委托来写tab切换

<!DOCTYPE html>
<html><head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1.0"><title>练习</title><style>* {margin: 0;padding: 0;}.tab {width: 590px;height: 340px;margin: 20px;border: 1px solid #e4e4e4;}.tab-nav {width: 100%;height: 60px;line-height: 60px;display: flex;justify-content: space-between;}.tab-nav h3 {font-size: 24px;font-weight: normal;margin-left: 20px;}.tab-nav ul {list-style: none;display: flex;justify-content: flex-end;}.tab-nav ul li {margin: 0 20px;}.tab-nav ul li a {text-decoration: none;color: #333;border-bottom: 2px solid transparent;font-size: 14px;}.tab-nav ul li a.active {border-color: #e1251b;color: #e1251b;}.tab-content {padding: 0 16px;}.item {display: none;}.item.active {display: block;}</style></head><body><div class="tab"><div class="tab-nav"><h3>每日特价</h3><ul><li><a class="active" href="javascript:;" data-id="0">精选</a></li><li><a href="javascript:;" data-id="1">美食</a></li><li><a href="javascript:;" data-id="2">百货</a></li><li><a href="javascript:;" data-id="3">个护</a></li><li><a href="javascript:;" data-id="4">预告</a></li></ul></div><div class="tab-content"><div class="item active"><img src="./06-素材(1)/images/tab00.png" alt=""></div><div class="item "><img src="./06-素材(1)/images/tab01.png" alt=""></div><div class="item "><img src="./06-素材(1)/images/tab02.png" alt=""></div><div class="item "><img src="./06-素材(1)/images/tab03.png" alt=""></div><div class="item "><img src="./06-素材(1)/images/tab04.png" alt=""></div></div></div><script>const ul = document.querySelector('.tab-nav ul')ul.addEventListener('click', function (e) {if (e.target.tagName === 'A') {document.querySelector('.tab-nav .active').classList.remove('active')e.target.classList.add('active')const i = +e.target.dataset.iddocument.querySelector('.tab-content .active').classList.remove('active')document.querySelector(`.tab-content .item:nth-child(${i + 1})`).classList.add('active')}})</script>
</body></html>

4.阻止默认行为

e.preveDefault()防止直接提交直接跳转

5.其他事件

页面加载事件:加载外部资源(图片,外联css,javascript)加载完毕时触发的事件

load

window.addEventListener(‘load’,function(){})所有资源加载完毕

也可以针对某个资源绑定load事件

DOMContentLoaded事件,当初始的html文档被完全加载和解析完之后

document.addEventListener(‘DOMContentLoaded’,function(){})

元素滚动事件:监听整个页面滚动,

<body><script>window.addEventListener('scroll',function(){console.log('11');})</script>
</body>

获取位置:scrollLeft和scrollTop

  <script>const div=document.querySelector('div')div.addEventListener('scroll',function(){console.log(div.scrollTop)})</script>

获得页面的滚动距离:document.documentElement.scrollTop得到的是数字型,不带单位

可以赋值document.documentElement.scrollTop=800

http://www.lryc.cn/news/510819.html

相关文章:

  • 7-1求逆序对数目
  • C# 中 Webclient和Httpclient
  • cesium入门学习三
  • swagger,showdoc,apifox,Mock 服务,dubbo,ZooKeeper和dubbo的关系
  • 【自信息、信息熵、联合熵、条件熵、互信息】
  • 免费资源网站
  • C++--------继承
  • Python PyMupdf 去除PDF文档中Watermark标识水印
  • 改进爬山算法之四:概率爬山法(Probabilistic Hill Climbing,PHC)
  • 解读DeepseekV3
  • 【网络安全 | 漏洞挖掘】如何通过竞态条件发现账户接管漏洞
  • 串口通信标准RS232、RS422、RS485有什么区别和不同
  • win版ffmpeg的安装和操作
  • 力扣56. 合并区间
  • 2024基于大模型的智能运维(附实践资料合集)
  • Android Java 版本的 MSAA OpenGL ES 多重采样
  • YOLO11改进-注意力-引入自调制特征聚合模块SMFA
  • VMware虚拟机安装银河麒麟操作系统KylinOS教程(超详细)
  • Elasticsearch-索引的批量操作
  • 【Android】application@label 属性属性冲突报错
  • 手机发烫怎么解决?
  • 【Artificial Intelligence篇】AI 携手人类:共铸未来创作新纪元
  • 小米路由器开启SSH,配置阿里云ddns,开启外网访问SSH和WEB管理界面
  • Go快速开发框架2.6.0版本更新内容快速了解
  • 条件语句 - if, else, switch-case
  • Flink CDC MySQL 同步数据到 Kafka实践中可能遇到的问题
  • 代码随想录Day51 99. 岛屿数量,99. 岛屿数量,100. 岛屿的最大面积。
  • 说说 DinoGrid Open Edition 算法生成艺术背后的故事
  • FFmpeg推拉流命令
  • 【图像处理lec10】图像压缩