使用原生的javascript来实现轮播图
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title></title>
- <style type="text/css">
- * {
- padding: 0;
- margin: 0;
- list-style: none;
- border: 0;
- }
- .all {
- width: 500px;
- height: 200px;
- padding: 7px;
- border: 1px solid #ccc;
- margin: 100px auto;
- position: relative;
- }
- .screen {
- width: 500px;
- height: 200px;
- overflow: hidden;
- position: relative;
- }
- .screen li {
- width: 500px;
- height: 200px;
- overflow: hidden;
- float: left;
- }
- .screen ul {
- position: absolute;
- left: 0;
- top: 0px;
- width: 3000px;
- }
- .all ol {
- position: absolute;
- right: 10px;
- bottom: 10px;
- line-height: 20px;
- text-align: center;
- }
- .all ol li {
- float: left;
- width: 20px;
- height: 20px;
- background: #fff;
- border: 1px solid #ccc;
- margin-left: 10px;
- cursor: pointer;
- }
- .all ol li.current {
- background: yellow;
- }
- #arr {
- display: none;
- }
- #arr span {
- width: 40px;
- height: 40px;
- position: absolute;
- left: 5px;
- top: 50%;
- margin-top: -20px;
- background: #000;
- cursor: pointer;
- line-height: 40px;
- text-align: center;
- font-weight: bold;
- font-family: '黑体';
- font-size: 30px;
- color: #fff;
- opacity: 0.3;
- border: 1px solid #fff;
- }
- #arr #right {
- right: 5px;
- left: auto;
- }
- </style>
- </head>
- <body>
- <div class="all" id='box'>
- <div class="screen">
- <ul>
- <li><img src="data:images/1.jpg" width="500" height="200"/></li>
- <li><img src="data:images/2.jpg" width="500" height="200"/></li>
- <li><img src="data:images/3.jpg" width="500" height="200"/></li>
- <li><img src="data:images/4.jpg" width="500" height="200"/></li>
- <li><img src="data:images/5.jpg" width="500" height="200"/></li>
- </ul>
- <ol>
- </ol>
- </div>
- <div id="arr"><span id="left"><</span><span id="right">></span></div>
- </div>
- <script>
- function $(element) {
- return document.getElementById(element);
- }
- var box = $("box");
- var screen = box.children[0];
- var ul = screen.children[0];
- var ulLis = ul.children;
- var ol = screen.children[1];
- var arr = $("arr");
- var left = $("left");
- var right = $("right");
- //动态创建小图标
- for (var i = 0; i < ulLis.length; i++) {
- var li = document.createElement("li");
- li.innerHTML = i + 1;
- ol.appendChild(li);
- }
- //设置这些个小图标
- var olLis = ol.children;
- var imgWidth = screen.offsetWidth;
- for (var j = 0; j < olLis.length; j++) {
- olLis[j].index = j;
- olLis[j].onmouseover = function () {
- //排他思想
- for (var i = 0; i < olLis.length; i++) {
- olLis[i].className = "";
- }
- this.className = "current";
- var target = -imgWidth * this.index;
- cutton(ul, target, 20);
- //为了让点击事件和小面的小图标能够一一对应,设置他们的索引值相同
- pic = square = this.index;
- }
- }
- //给小图标设置一个初始样式
- ol.children[0].className = "current";
- //给ul追加一张图
- ul.appendChild(ul.children[0].cloneNode(true));
- //设置箭头的显示与隐藏
- box.onmouseover = function () {
- arr.style.display = "block";
- //鼠标放上去的时候,不再自动滚动
- clearInterval(timer);
- }
- box.onmouseout = function () {
- arr.style.display = "none";
- //鼠标离开的时候,继续自动滚动
- timer = setInterval(playNext, 1000);
- }
- //设置点击左右小箭头的事件且要求小图标要跟着变化
- //1.设置点击右侧箭头
- var pic = 0;//记录当前为第几项用
- var square = 0;//记录小图标的索引值
- /* right.onclick = function () {//存在的问题是当移动到最后一张的时候,无法跳转到第一张
- pic++;
- var target = -pic * imgWidth;
- cutton(ul, target, 20);
- }*/
- //方法改进
- /*right.onclick = function () {
- //先对pic做一个判断,当pic的值为5的时候,实现一个跳转
- if (pic == ulLis.length - 1) {
- ul.style.left = 0;
- pic = 0;
- }
- pic++;
- var target = -pic * imgWidth;
- cutton(ul, target, 20);
- if (square == olLis.length - 1) {
- square = -1;//下面会加一,就变成了0
- }
- square++;
- //排他思想
- for (var i = 0; i < olLis.length; i++) {
- olLis[i].className = "";
- }
- olLis[square].className = "current";
- }*/
- //使用封装函数
- right.onclick = function () {
- playNext();
- }
- //2.设置点击左侧箭头
- left.onclick = function () {//要判断一下当pic为零时的情况
- if (pic == 0) {
- ul.style.left = -imgWidth * (ulLis.length - 1) + "px";//要记得加单位
- pic = ulLis.length - 1;//给pic重新赋一个值
- }
- pic--;
- var target = -pic * imgWidth;
- cutton(ul, target, 20);
- //设置小图标样式
- if (square == 0) {
- square = olLis.length;
- }
- square--;
- for (var i = 0; i < olLis.length; i++) {
- olLis[i].className = "";
- }
- olLis[square].className = "current";
- }
- //设置自动滚动
- //1.封装点击右侧小箭头事件
- function playNext() {
- //先对pic做一个判断,当pic的值为5的时候,实现一个跳转
- if (pic == ulLis.length - 1) {
- ul.style.left = 0;
- pic = 0;
- }
- pic++;
- var target = -pic * imgWidth;
- cutton(ul, target, 20);
- if (square == olLis.length - 1) {
- square = -1;//下面会加一,就变成了0
- }
- square++;
- //排他思想
- for (var i = 0; i < olLis.length; i++) {
- olLis[i].className = "";
- }
- olLis[square].className = "current";
- }
- //2.调用这个封装的函数,并且设置一个间歇性计时器
- var timer = null;
- timer = setInterval(playNext, 1000);
- //封装函数
- function cutton(obj, target, stp) {
- clearInterval(obj.timer);
- obj.timer = setInterval(function () {
- var step = stp;
- step = obj.offsetLeft > target ? -step : step;
- if (Math.abs(obj.offsetLeft - target) >= Math.abs(step)) {
- obj.style.left = obj.offsetLeft + step + "px";
- } else {
- obj.style.left = target + "px";
- clearInterval(obj.timer);
- }
- }, 15)
- }
- </script>
- </body>
- </html>
使用原生的javascript来实现轮播图的更多相关文章
- 原生JS面向对象思想封装轮播图组件
原生JS面向对象思想封装轮播图组件 在前端页面开发过程中,页面中的轮播图特效很常见,因此我就想封装一个自己的原生JS的轮播图组件.有了这个需求就开始着手准备了,代码当然是以简洁为目标,轮播图的各个功能 ...
- 原生JS实现移动端轮播图
功能描述: 自动无缝轮播图片,底部小圆点跟图片保持一致:手指左右移动轮播图,移动距离大于50px播放下一张(或上一张),小于50px则回弹 具体功能实现: 1.定时器 自动轮播图片 先声明一个inde ...
- Web前端原生JavaScript浅谈轮播图
1.一直来说轮播图都是困扰刚进业内小白的一大难点,因为我们不仅需要自己作出一个比较完美的运动框架(虽然网上一抓一大把,但是哪有比自己做出来实现的有成就感,不是吗?^_^),还必须需要非常关键性的把握住 ...
- 原生javascript之实战 轮播图
成品效果如下图所示: 因为博客园限制图片上传大小被我删了一些帧数,所以图片看起来会有一点卡,现实运行是不会的 搭建HTML和CSS结构 HTML代码如下: <div class="wr ...
- 从零开始学习前端JAVASCRIPT — 11、JavaScript运动模型及轮播图效果、放大镜效果、自适应瀑布流
未完待续...... 一.运动原理 通过连续不断的改变物体的位置,而发生移动变化. 使用setInterval实现. 匀速运动:速度值一直保持不变. 多物体同时运动:将定时器绑设置为对象的一个属性. ...
- 用JavaScript制作banner轮播图
JavaScript_banner轮播图 让我们一起来学习一下用js怎么实现banner轮播图呢? 直接看代码: <!DOCTYPE html> <html> <head ...
- JavaScript实现动态轮播图效果
功能描述: 1.鼠标经过 左右侧箭头显示,鼠标离开 箭头隐藏 2.动态添加底部小圆圈并绑定单击事件,并且让小圆圈的点击事件和左右箭头点击事件同步 3.拷贝第一张图片添加到ul最后可以实现动态添加图片 ...
- 原生js实现响应式轮播图,支持电脑端点击切图,手机端滑动切图
轮播图的实现原理并不难,但是步骤有些繁琐.最近练习了一个轮播图,大部分是跟着网上的教程写的,然后自己做了一点兼容ie8的修改,加了点击切换图片的特效和手机端的滑动特效,让这个轮播图可以在响应式的网站中 ...
- 原生js写一个无缝轮播图插件(支持vue)
轮播图插件(Broadcast.js) 前言:写这个插件的原因 前段时间准备用vue加上网易云的nodejs接口,模拟网易云音乐移动端.因为想自己写一遍所有的代码以及加固自己的flex布局,所以没有使 ...
随机推荐
- js 常见事件
- Clarke Award for Imagination in Service to Society刘慈欣演讲
刘慈欣不无批评地写道(http://cn.chinadaily.com.cn/2018-11/12/content_37243853.htm): 科幻的想象力由克拉克的广阔和深远,变成赛博朋克的狭窄和 ...
- android viewpager 拿到当前显示的 fragment 的实例
一个 ViewPager 通过 FragmentPagerAdapter 绑定了 3 个 fragment 可以通过 Fragment fragment = getSupportFragmentMan ...
- Redis的安装(CentOS 7下)
redis的官网,www.redis.io 1. 先下载 redis: wget http://download.redis.io/releases/redis-3.0.3.tar.gz 2. 解压: ...
- PHP中判断字符串是否包含某个字符时,建议使用正则表达式preg_match()
判断字符串中是否包含 某个字符时,在java中时直接使用 indexOf()来判断的 在php中好像也要对应的,strpos(),stripos() 不过每次我用的都很不爽,老是出现各种各样的小问题, ...
- win10中xshell的ssh链接virtualBox中的centos7
win10下virtualbox中centos7.3与主机通过xshell的ssh建立连接的方法 2017-02-19 01:29 版权声明:本文为博主原创文章,未经博主允许不得转载. 最近 ...
- ExtJs6解决添加和修改Form共用一个form的隐藏域的id的取消传值
问题重现:修改不会有问题,id会绑定之前的grid,有具体数字 添加有问题,因为id是空,传的是绑定值的话会显示“类名-1”,从int类型变成了string类型,后台会出错 这是EduQuestion ...
- HDU 5690——All X——————【快速幂 | 循环节】
All X Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submi ...
- FZU 2138——久违的月赛之一——————【贪心】
久违的月赛之一 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit Stat ...
- 巧用hover改变css样式和背景
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...