美文网首页
A30-无缝轮播

A30-无缝轮播

作者: 半斋 | 来源:发表于2018-02-06 20:10 被阅读0次

任务代码

预览

用到的新 API

  1. .on('transitionend') -link
  2. 更多事件见-事件类型一览表
  3. .one() 为元素的事件添加处理函数。处理函数在每个元素上每种事件类型最多执行一次。 -link
  4. ES6-模板字符串-表达式插补(${expression})

DOM事件模型

W3C
DOM Level 0: 在 W3C 出来之前的事实规范,比如 onclick,onmouseenter……或者直接在html里面写js函数
DOM Level 1: W3C整合之前的DOM0并没有做任何变更
DOM Level 2: 提供了 addEventListener 和 removeEventListener 等函数,这两个函数和onclick不同,onclick是属性,写第二个就会覆盖上一个,而addEventListener你可以认为是一个事件队列,一个事件一个队列,你可以往队列里添加多个函数,他们会按照顺序依次执行,removeEventListener则是将函数从队列中删除
同时,DOM2添加了两个阶段,捕获和冒泡

<div id="grand">
  grand
  <div id="parent">
    parent
    <div id="child">child</div>
  </div>
</div>
// 先捕获,后冒泡
// 第三个参数默认为false,即冒泡阶段执行函数
grand.addEventListener('click', function(){console.log(grand)})
parent.addEventListener('click', function(){console.log(parent)})
child.addEventListener('click', function(){console.log(child)})
// 点击child div
// child  parent  grand

// 第三个参数为 true,即捕获阶段执行函数
grand.addEventListener('click', function(){console.log(grand)}, true)
parent.addEventListener('click', function(){console.log(parent)}, true)
child.addEventListener('click', function(){console.log(child)}, true)
// 点击child div
// grand parent child

// 如果是同一个div的话
child.addEventListener('click', function(){console.log(child1)}, false)
child.addEventListener('click', function(){console.log(child2)}, true)
// 点击
// child1 dhild2
// 同一个不管第三个参数,他们按js代码书写顺序执行

相关文章

  • A30-无缝轮播

    任务代码 预览 用到的新 API .on('transitionend') -link 更多事件见-事件类型一览表...

  • 无缝轮播

    无缝细解过程 html css js 无缝轮播js切换动画 css代码 JS代码 循环无缝轮播 CSS js1.首...

  • JS中常见的几种轮播

    轮播图 1.无缝不停轮播 ​ 1. body布局: ​ 2. css样式: 3. JS代码: 2.无缝停顿...

  • 无缝轮播

    轮播图大家都写过,但是怎么做到无缝切换对初学者来说是个难点。曾经也困惑了我很久,一直在研究,方法也很多,但是总是没...

  • 无缝轮播

    给大家讲哈无缝轮播吧~ 首先说一下布局~~ 然后加个隐藏 如图 如图 如图,就可以切换了 如图,都可以切换出来啦

  • 无缝轮播

    无缝轮播原理 DOM events 1.历史 2.例子 类型是程序员要注重2队列 先进先出一次事件 .one() ...

  • 无缝轮播

    代码

  • 轮播图的制作

    这是渐变方法的无限轮播哈哈,附带autoPlay无缝无限轮播多个carouselcarousel-fullscreen

  • jQuery实现轮播图无缝(无回滚)滚动切换效果

    HTML 无缝切换轮播图