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