jQuery制作全屏宽度固定高度轮播图(实例讲解)


Posted in jQuery onJuly 08, 2017

前端新手自己写的,练习一下基本功,也是留下的第一次记录

html部分

div class="cm-banner">
  <div class="cm-banner-list">
    <ul id="cm_banner_list">
      <!--图片宽度和高度在css中定为1920x300-->
      <li><img src="cm-banner-01.png" /></li>
      <li><img src="cm-banner-02.png" /></li>
      <li><img src="cm-banner-03.png" /></li>
      <li><img src="cm-banner-04.png" /></li>
    </ul>
    <ul class="cm-banner-num" id="cm_banner_num"></ul>
  </div>
  <div class="cm-banner-in w">
    <img src="cm-arrow-left.png" id="cm_prev" class="cm-banner-arrow" />
    <img src="cm-arrow-right.png" id="cm_next" class="cm-banner-arrow" />
  </div>
</div>

css部分

*{
  margin: 0;
  padding: 0;
}
.cm-banner {
  width: 100%;
  height: 300px;
  overflow: hidden;
  cursor: pointer;
  position: relative;
}

.cm-banner-in {
  width: 1100px;
  height: 300px;
  position: absolute;
  top: 0;
  left: 50%;
  margin-left: -550px;
}

#cm_banner_list li{
  display: none;
  position: absolute;
  top: 0;
  left: 0;
}

.cm-banner-num {
  width: 100%;
  position: absolute;
  bottom: 0;
  text-align: center;
  z-index: 2; /*如果没有在这里设置层次小圆点的点击效果无法触发*/
}

.cm-banner-num li{
  width: 10px;
  margin: 10px 3px;
  height: 10px;
  background-color: #fff;
  border-radius: 5px;
  -webkit-border-radius: 5px;
  display: inline-block;
  opacity: 0.7;
}

.cm-banner-num .active {
  background-color: #3982de;
}

.cm-banner-arrow {
  position: absolute;
  top: 50%;
  margin-top: -22px;
  opacity: 0.5;
  display: none;
}

#cm_prev {
  left: 0;
}

#cm_next {
  right: 0;
}

js部分

$(function(){
  //鼠标移入显示箭头按钮
  $('.cm-banner').hover(function(){
    $('.cm-banner-arrow').show();
    clearInterval(cm_timer);
  },function(){
    $('.cm-banner-arrow').hide();
    cm_timer = setInterval(function(){
      i++;
      if(i > cm_length - 1){
        i = 0;
      }
      $('#cm_banner_list li').eq(i).fadeIn(800).siblings().fadeOut(800);
      cm_toggle(i);
    },2500);
  });

  //鼠标移入箭头按钮高亮
  $('.cm-banner-arrow').hover(function(){
    $(this).css('opacity','1');
  },function(){
    $(this).css('opacity','0.5');
  });

  //初始化必要变量
  var i = 0;
  var cm_length = $('#cm_banner_list li').length;
  var cm_toggle = function(point){
    $('#cm_banner_num li').eq(point).addClass('active').siblings().removeClass('active');
  };

  //动态添加小圆点
  for(j = 0;j < cm_length;j++){
    $('#cm_banner_num').append('<li></li>');
  }

  //给第一个小圆点添加样式
  $('#cm_banner_num li').first().addClass('active');

  //给第一张图片添加样式
  $('#cm_banner_list li').first().css('display','block');

  //鼠标点击左箭头切换
  $('#cm_prev').click(function(){
    i--;
    if(i < 0){
      i = cm_length - 1;
    }
    $('#cm_banner_list li').eq(i).fadeIn(800).siblings().fadeOut(800);
    cm_toggle(i);
  });

  //鼠标点击右箭头切换
  $('#cm_next').click(function(){
    i++;
    if(i > cm_length - 1){
      i = 0;
    }
    $('#cm_banner_list li').eq(i).fadeIn(800).siblings().fadeOut(800);
    cm_toggle(i);
  });

  //鼠标点击圆点切换
  $('#cm_banner_num li').click(function(){
    var cm_index = $(this).index();
    $('#cm_banner_list li').eq(cm_index).fadeIn(800).siblings().fadeOut(800);
    i = cm_index;
    cm_toggle(cm_index);
  });

  //自动播放
  cm_timer = setInterval(function(){
    i++;
    if(i > cm_length - 1){
      i = 0;
    }
    $('#cm_banner_list li').eq(i).fadeIn(800).siblings().fadeOut(800);
    cm_toggle(i);
  },2500);
});

以上这篇jQuery制作全屏宽度固定高度轮播图(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

jQuery 相关文章推荐
jquery中封装函数传递当前元素的方法示例
May 05 jQuery
jQuery 中msgTips 顶部弹窗效果实现代码
Aug 14 jQuery
详解在vue-cli中引用jQuery、bootstrap以及使用sass、less编写css
Nov 08 jQuery
jQuery实现标签子元素的添加和赋值方法
Feb 24 jQuery
[原创]jquery判断元素内容是否为空的方法
May 04 jQuery
jQuery实现仿京东防抖动菜单效果示例
Jul 06 jQuery
jQuery扩展方法实现Form表单与Json互相转换的实例代码
Sep 05 jQuery
jQuery实现点击图标div循环放大缩小功能
Sep 30 jQuery
jQuery操作元素追加内容示例
Jan 10 jQuery
jquery简易手风琴插件的封装
Oct 13 jQuery
jQuery插件实现图片轮播效果
Oct 19 jQuery
JQuery+drag.js上传图片并且实现图片拖曳
Nov 18 jQuery
JQuery 获取Dom元素的实例讲解
Jul 08 #jQuery
深入理解jquery的$.extend()、$.fn和$.fn.extend()
Jul 08 #jQuery
浅谈jQuery框架Ajax常用选项
Jul 08 #jQuery
jQuery 实现图片的依次加载图片功能
Jul 06 #jQuery
jQuery+ajax实现修改密码验证功能实例详解
Jul 06 #jQuery
jQuery实现选中行变色效果(实例讲解)
Jul 06 #jQuery
运用jQuery写的验证表单(实例讲解)
Jul 06 #jQuery
You might like
laravel利用中间件防止未登录用户直接访问后台的方法
2019/09/30 PHP
JQUERY的属性选择符和自定义选择符使用方法(二)
2011/04/07 Javascript
JQuery之focus函数使用介绍
2013/08/20 Javascript
JavaScript函数的4种调用方法详解
2014/04/22 Javascript
关于JavaScript命名空间的一些心得
2014/06/07 Javascript
BootstrapTable+KnockoutJS自定义T4模板快速生成增删改查页面
2016/08/01 Javascript
Bootstrap警告(Alerts)的实现方法
2017/03/22 Javascript
angular中使用Socket.io实例代码
2017/06/03 Javascript
nodejs实现简单的gulp打包
2017/12/21 NodeJs
Nginx 配置多站点vhost 的方法
2018/01/07 Javascript
微信小程序实现YDUI的ScrollTab组件
2018/02/02 Javascript
vue实现滑动切换效果(仅在手机模式下可用)
2020/06/29 Javascript
iview form清除校验状态的实现
2019/09/19 Javascript
简单谈谈offsetleft、offsetTop和offsetParent
2020/12/04 Javascript
[01:54]TI珍贵瞬间系列(五):压力
2020/08/29 DOTA
python笔记(2)
2012/10/24 Python
python数据处理实战(必看篇)
2017/06/11 Python
微信跳一跳游戏python脚本
2020/04/01 Python
Python tornado队列示例-一个并发web爬虫代码分享
2018/01/09 Python
python实现画圆功能
2018/01/25 Python
Flask Web开发入门之文件上传(八)
2018/08/17 Python
详解Python解决抓取内容乱码问题(decode和encode解码)
2019/03/29 Python
台湾最大网路书店:博客来
2018/03/18 全球购物
英国婚礼商城:Wedding Mall
2019/11/02 全球购物
Richards网上商店:当代时尚,遍布巴西
2019/11/03 全球购物
优秀老师事迹材料
2014/02/05 职场文书
学校安全责任书
2014/04/14 职场文书
幼儿园教师节演讲稿
2014/09/03 职场文书
2014副镇长民主生活会个人对照检查材料思想汇报
2014/09/30 职场文书
幼儿园教师考核评语
2014/12/31 职场文书
父亲节寄语大全
2015/02/27 职场文书
《1942》观后感
2015/06/08 职场文书
2016庆祝国庆67周年宣传语
2015/11/25 职场文书
vue响应式原理与双向数据的深入解析
2021/06/04 Vue.js
世界无敌的ICOM IC-R9500宽频接收机
2022/03/25 无线电
Redis分布式锁的7种实现
2022/04/01 Redis