js学习总结_轮播图之渐隐渐现版(实例讲解)
时间:2019-03-30
本文章向大家介绍js学习总结_轮播图之渐隐渐现版(实例讲解),主要包括js学习总结_轮播图之渐隐渐现版(实例讲解)使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
具体代码如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style> *{ margin:0; padding:0; font-size:14px; -webkit-user-select:none; } ul,li{ list-style } img{ display: block; border:none; } .banner{ position:relative; width:1000px; height:300px; margin:0 auto; overflow:hidden; } .banner .bannerInner{ width:100%; height:100%; background:url("../img/default.gif") no-repeat center center #e1e1e1; } .banner .bannerInner div{ position:absolute; width:100%; height:100%; top:0; left:0; z-index:0; opacity:0; filter:alpha(opacity=0); } .banner .bannerInner img{ display:none; width:100%; height:100%s; } .banner .bannerTip{ position:absolute; height:18px; overflow:hidden; right:20px; bottom:20px; z-index:10; } .banner .bannerTip li{ float:left; margin-left:10px; width:18px; height:18px; background:lightblue; cursor:pointer; border-radius:50%; } .banner .bannerTip li.bg{ background:red; } .banner a{ display:none; position:absolute; top:50%; z-index:20; margin-top:-22.5px; width:30px; height:45px; background:url("../img/pre.png"); opacity:0.5; filter:alpha(opacity=50); } .banner a:hover{ opacity:1; filter:alpha(opacity=100); } .banner a.bannerLeft{ left:20px; background-position:0 0; } .banner a.bannerRight{ right:20px; background-position:-50px 0; } </style> </head> <body> <div class='banner' id='banner'> <div class='bannerInner'> <div><img src="" alt="" trueImg="img/banner1.jpg"></div> <div><img src="" alt="" trueImg="img/banner2.jpg"></div> <div><img src="" alt="" trueImg="img/banner3.jpg"></div> <div><img src="" alt="" trueImg="img/banner4.jpg"></div> </div> <ul class='bannerTip'> <li class='bg'></li> <li></li> <li></li> <li></li> </ul> <a href="javascript:;" rel="external nofollow" rel="external nofollow" class='bannerLeft'></a> <a href="javascript:;" rel="external nofollow" rel="external nofollow" class='bannerRight'></a> </div> <script> var banner = document.getElementById('banner'); var bannerInner = utils.firstChild(banner),bannerTip = utils.children(banner,"ul")[0],bannerLink = utils.children(banner,'a'),bannerLeft = bannerLink[0],bannerRight = bannerLink[1]; var divList = bannerInner.getElementsByTagName('div'); var imgList = bannerInner.getElementsByTagName('img'); var oLis = bannerTip.getElementsByTagName('li'); //1、Ajax读取数据 var jsonData = null; ~function(){ var xhr = new XMLHttpRequest; xhr.open("get","json/banner.txt?_="+Math.random(),false); xhr.onreadystatechange = function(){ if(xhr.readyState ===4 && /^2\d{2}$/.test(xhr.status)){ jsonData = utils.formatJSON(xhr.responseText) } } xhr.send(null) }() //2、数据绑定 ~function(){ var str = "",str2 = ""; if(jsonData){ for(var i = 0,len=jsonData.length;i<len;i++){ var curData = jsonData[i]; str+='<div><img src="" alt="" trueImg="'+curData['img']+'"></div>'; i===0?str2+="<li class='bg'></li>":str2+="<li></li>" } } bannerInner.innerHTMl = str; bannerTip.innerHTML = str2; }() //3、图片的延迟加载 window.setTimeout(lazyImg,500) function lazyImg(){ for(var i = 0,len = imgList.length;i<len;i++){ ~function(i){ var curImg = imgList[i]; var oImg = new Image; oImg.src = curImg.getAttribute('trueImg'); oImg.onload = function(){ curImg.src = this.src; curImg.style.display = block; //只对第一张处理 if(i===0){ var curDiv = curImg.parentNode; curDiv.style.zIndex = 1; myAnimate(curDiv,{opacity:1},200); } oImg = null; } }(i) } } //4、自动轮播 var interval = 3000,autoTimer = null,step = 0; autoTimer = window.setInterval(autoMove,interval); function autoMove(){ //当已经把最后一张展示完成后(step等于最后一张的索引),我们应该展示第一张,我们让step = -1,这样再经过一次累加,step就变为0,来展示第一张 if(step === jsonData.length-1){ step = -1 } step++; setBanner(); } //实现轮播图切换效果的代码 function setBanner(){ //1、让step索引对应的那个DIV的zIndex的值为1,其他的zIndex为0 for(var i = 0,len = divList.length;i<len;i++){ var curDiv = divList[i]; if(i===step){ utils.css(curDiv,"zIndex",1) //2、让当前的透明度从0变为1,当动画结束,我们需要让其他的div的透明度的值直接变为0 myAnimate(curDiv,{opacity:1},200,function(){ var curDivSib = utils.siblings(this); for(var k = 0,len = curDivSib.length;k<len;k++){ utils.css(curDivSib[k],'opacity',0) } }) continue } utils.css(curDiv,"zIndex",0) } //实现焦点对其 for(i = 0,len = oLis.length;i<len;i++){ var curLi = oLis[i]; i === step?utils.addClass(curLi,"bg"):utils.removeClass(curLi,"bg"); } } //5、实现鼠标悬停停止自动轮播和离开在开启自动轮播 banner.onmouseover = function(){ window.clearInterval(autoTimer); bannerLeft.style.display = bannerRight.style.display = "block" } banner.onmouseout = function(){ autoTimer = window.setInterval(autoMove,interval); bannerLeft.style.display = bannerRight.style.display = "none" } //6、实现点击焦点切换 ~function(){ for(var i = 0,len = oLis.length;i<len;i++){ var curLi = oLis[i]; curLi.index = i; curLi.onclick = function(){ step = this.index; setBanner(); } } }() //7、实现左右切换 bannerRight.onclick = autoMove; bannerLeft.onclick = function(){ if(step === 0){ step = jsonData.length; } step--; setBanner(); } </script> </body> </html>
以上这篇js学习总结_轮播图之渐隐渐现版(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
- PHP7 下的协程实现
- 单点登录系统实现
- Spring 注解概览
- 走进 Redis:Redis 的安装、使用以及集群的搭建
- 基于 PHPStorm 编辑器的 Laravel 开发
- 再见乱码:5 分钟读懂 MySQL 字符集设置
- PHP 高级面试题 - 如果没有 mb 系列函数,如何切割多字节字符串
- 如何做一个小程序口令红包功能
- 使用思维导图,优雅的完成自己的代码
- 移动端布局攻略
- nginx反向代理https网站 并实现网站的注册和登录功能
- 通过nginx GeoIP模块 限制某些国家地区访问网站
- CDN加速下通过nginx获取网站访客真实ip
- linux centos7服务器使用密钥登录ssh同时禁止root密码登录
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 微信小程序自动化测试最佳实践(附 Python 源码)
- 3分钟短文 | MySQL在分组时,把多列合并为一个字段!
- Redis Linux系统参数最佳配置
- 实现Promise其它API
- 使用sysbench进行压测 Part1 sysbench安装
- Java并发编程(07):Fork/Join框架机制详解
- PostgreSQL Pgbouncer 到底怎么使用,疗效有多大
- 微信练手小程序源码 - 日历(含各种功能组件)
- Redis 5.0.8安装
- Redis 主从搭建
- Redis 5.0.8 主从+哨兵的搭建
- ammo.js-bullet物理引擎碰撞检测
- TKE上动态部署jenkins slaves
- CVE-2017-0261及利用样本分析
- 流水的NLP铁打的NER:命名实体识别实践与探索