javascript点击事件中的捕获/冒泡运用
2016-07-15 13:30
288 查看
版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/m9365859/article/details/51916944
运用javascript事件的三个阶段实现点击,颜色从点击处向外扩散
<pre name="code" class="html"><style> *{margin:0px;padding:0px;box-sizing:border-box;transition: background 800ms;padding:20px;} body,html{height: 100%;} body{ background:#40b7d8;} html{ background:#6bc7e1;} div{height:100%; background: #95d7ea;} p{height:100%; background: #c0e7f2;} span{height:100%; background: #eaf7fb;display: block;} .highlight {background: red;} </style>
<div> <p> <span style="white-space:pre"> </span><span>Click on a layer to watch the event move through the DOM tree</span> </p> </div>
<script type="text/javascript"> var panit=200; var a; window.οnlοad=function(){ var body=document.body; var html=document.documentElement; var div=body.querySelector('div'); var p=body.querySelector('p'); var span=body.querySelector('span'); addListener(div,'click',callback); addListener(p,'click',callback); addListener(span,'click',callback); } var addListener=(function(){ if(document.attachEvent){ return function(element,event,handler){ element.attachEvent('on'+event,function(event){ var event=window.event; event.target=event.srcElement; event.currentTarget=element; handler.call(element,event) }) } }else{ return function(element,event,handler){ element.addEventListener(event,handler,false) } } }()) function callback(event){ var ms=a= (a+panit)||0; var current=event.currentTarget; setTimeout(function(){ current.className='highlight'; setTimeout(function(){ current.className=''; },panit) },ms) } </script>
相关文章推荐
- JavaScript-父子dom同时绑定两个点击事件,一个用捕获,一个用冒泡时执行顺序
- JavaScript-父子dom同时绑定两个点击事件,一个用捕获,一个用冒泡时执行顺序
- JavaScript-父子dom同时绑定捕获冒泡点击事件时执行顺序
- JavaScript实现父子dom同时绑定两个点击事件,一个用捕获,一个用冒泡时执行顺序的方法
- JavaScript事件捕获与事件冒泡原理
- javascript事件冒泡与事件捕获
- JavaScript中的事件冒泡与捕获
- javascript事件冒泡与事件捕获
- javascript事件之:事件冒泡, 事件捕获 ,默认事件阻止
- Javascript事件模型:事件捕获和事件冒泡
- 浅谈javascript中的事件冒泡和事件捕获
- 你根本不懂Javascript(5): HTML事件捕获与冒泡
- Javascript事件模型:事件捕获和事件冒泡
- javascript事件冒泡详解和捕获、阻止方法
- 事件流之事件冒泡与事件捕获<JavaScript高级程序设计>学习笔记
- Javascript的事件冒泡和事件捕获,阻止事件冒泡,事件源target
- JavaScript高级程序设计笔记 事件冒泡和事件捕获
- javaScript事件捕获和冒泡
- JavaScript 详说事件机制之冒泡、捕获、传播、委托
- JavaScript示例六(事件冒泡与捕获)