结合了所学的简单运动框架~  做这样一个综合小实例~~

-------------------------主要问题:

1、getByClassName  IE低版的兼容性

2、DOM不够严谨 … 各种跳出和bug

3、实现方法麻烦~  代码完全与精简不挨边……

-------------------------解决方法:

- - 目前只能做到这样,慢慢学,慢慢进步了~

-------------------------要实现功能如下:

1、鼠标移入大图,左右按钮显示(控制opaicty)

2、当前显示的大图,对应小图全显,其他为半透明(控制opacity)

3、每张切换的大图窗格切换效果  (控制height运动)

4、小图的滚动播放,大图跟随(小图整个部分left的值)

5、自动播放,鼠标移入移出,停止 继续~(setInterval)

大致布局:

由外到内allWrap  从上到下topWrap  bottomWrap

topWrap里div里放大图, 按钮和其他显隐单独布出

bottomWrap里给个不设宽的ul~   让其宽度为li宽度*li的个数

------------------------------------------------------   javascript代码如下    --------------------------------

//这是上次的综合运动框架~  就不再写了

<script src="js/sports.js"></script>
<script>
// 执行函数
window.onload = function(){
  // 控制声明变量
  // 按钮效果
  var oAllWrap = document.getElementById('allWrap');
  var oBtn_LW = oAllWrap.getElementsByClassName('btnLeftWrap')[0];
  var oBtn_L = oAllWrap.getElementsByClassName('btnLeft')[0];
  var oBtn_RW = oAllWrap.getElementsByClassName('btnRightWrap')[0];
  var oBtn_R = oAllWrap.getElementsByClassName('btnRight')[0];

  // 大图切换
  var oPlace = oAllWrap.getElementsByClassName('placeholder')[0];
  var aP_img = oPlace.getElementsByTagName('img');
  var oB_Wrap = oAllWrap.getElementsByClassName('bottomWrap')[0];
  var oGallery = oB_Wrap.getElementsByClassName('gallery')[0];
  var aG_li = oGallery.getElementsByTagName('li');
  var oNowzIndex = 2;
  var oNowClick = 0;

  // 封装函数
  function tab(){
    // 1、点击小图,实现大图切换
    aP_img[oNowClick].style.zIndex = oNowzIndex++;
    // 2、点击后,当前点击小图透明度100%
    for(var j=0; j<aG_li.length; j++){
    moveStart(aG_li[j],'opacity',30);
    }
    moveStart(aG_li[oNowClick],'opacity',100);
    // 3、点击后,实现大图伸缩播放
    aP_img[oNowClick].style.height = 0;
    moveStart(aP_img[oNowClick],'height',400);

    // 4、点击后,图片的滚动播放特效
    // 若为第0张,不要变位置
    if( oNowClick == 0 ){
      moveStart(oGallery,'left',0);
    }
    // 若是最后张,位置变为倒数第二张一样
    else if( oNowClick == aG_li.length-1 ){
      moveStart(oGallery,'left',-aG_li[0].offsetWidth*(oNowClick-2) );
    }
    // 其他情况下才变动位置
    else{
      moveStart(oGallery,'left',-aG_li[0].offsetWidth*(oNowClick-1) );
    }
  }

/* -------------------------添加事件--------------------------------- */

  // 按钮效果
  oBtn_LW.onmouseover = oBtn_L.onmouseover = function(){
    moveStart(oBtn_L,'opacity',80);
  }
  oBtn_LW.onmouseout = function(){
    moveStart(oBtn_L,'opacity',0);
  }

  oBtn_RW.onmouseover = oBtn_R.onmouseover = function(){
    moveStart(oBtn_R,'opacity',80);
  }
  oBtn_RW.onmouseout = function(){
    moveStart(oBtn_R,'opacity',0);
  }
  //大图切换
  for(var i=0; i<aG_li.length; i++){

    // 让小图ul的宽度 等于 li宽度*li个数
    oGallery.style.width = aG_li[0].offsetWidth * aG_li.length + 'px';

    // 添加自定义属性 序号 index = i;
    aG_li[i].index = i;
    aG_li[i].onclick = function(){

    // 组合特效--------------1大图切换 2透明度 3伸缩播放  4滚动播放

    if(this.index == oNowClick)return;
    oNowClick = this.index;

    tab();

    }

    //小图移入移出透明度变化
    aG_li[i].onmouseover = function(){
    moveStart(this,'opacity',100);
    }

    aG_li[i].onmouseout = function(){
      if(this.index != oNowClick){
        moveStart(this,'opacity',30);
      }
    }
  }

  //左右按钮点击后效果
  oBtn_L.onclick = function(){
    oNowClick--;
    if(oNowClick == -1){
      oNowClick = aG_li.length-1;
    }
    tab();
  }

  oBtn_R.onclick = function(){
    oNowClick++;
    if(oNowClick == aG_li.length){
      oNowClick = 0;
    }
    tab();
  }

  // 设置自动播放~
  var timer_autoPlay = null;
  timer_autoPlay = setInterval(oBtn_R.onclick,3000);

  oAllWrap.onmouseover = function(){
    clearInterval(timer_autoPlay);
  }
  oAllWrap.onmouseout = function(){
    timer_autoPlay = setInterval(oBtn_R.onclick,3000);
  }

}

</script>

JS 阶段练习~ 仿flash的图片轮换效果的更多相关文章

  1. 仿FLASH的图片轮换效果

    css布局代码(test.css): body { background: #ccc;} ul { padding: 0; margin: 0;} li { list-style: none;} im ...

  2. 仿flash实现图片轮换播放

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. jQuery仿迅雷图片轮换效果

    jQuery仿迅雷图片轮换效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "ht ...

  4. Jquery实现图片轮换效果

    最近在看jquery书时,看到一个比较有趣的东西:图片轮换.这里和大家分享下我看完后写的一个demo.实现图片轮换要完成三部分模块:html部分.css部分.jqury部分.下面分步详细说明.1.ht ...

  5. Magnifier.js - 支持鼠标滚轮缩放的图片放大镜效果

    Magnifier.js 是一个 JavaScript 库,能够帮助你在图像上实现放大镜效果,支持使用鼠标滚轮放大/缩小功能.放大的图像可以显示在镜头本身或它的外部容器中.Magnifier.js 使 ...

  6. jquery带小图的图片轮换效果

    右边显示大图,左边显示小图 <style> ul{ list-style:none; padding:0px; margin:0px;} li{ list-style:none; padd ...

  7. 仿flash的文字动画效果

    .tips{ font-size: 24px; font-family: sans-serif; font-weight: 600; text-shadow: 1px 1px #ffb700; col ...

  8. DeWeb : 制作图片轮换效果

    演示:http://www.web0000.com/slide.dw源代码:http://www.web0000.com/media/source/slide.zip一.新建一个DLL二.除第一行外, ...

  9. 使用纯生js实现图片轮换

    效果图预览. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...

随机推荐

  1. 如何直接在 PC 端获取其它端设备的 UserAgent 信息呢?

    如何直接在 PC 端获取其它端设备的 UserAgent 信息呢 [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5909615.html 序 希望收 ...

  2. 查看当前数据库正在运行的Session

    当数据库运行比较缓慢时,我们需要实时查看当前有什么Session在运行,获得信息越完整,对于分析低性能的原因越有帮助.根据之前调优的经历,简单几步分析如下: 1.通过SQL Server内置的Sp_w ...

  3. SharePoint 2013 Create taxonomy field

    创建taxonomy field之前我们首先来学习一下如果创建termSet,原因是我们所创建的taxonomy field需要关联到termSet. 简单介绍一下Taxonomy Term Stor ...

  4. 【基于WPF+OneNote+Oracle的中文图片识别系统阶段总结】之篇二:基于OneNote难点突破和批量识别

    篇一:WPF常用知识以及本项目设计总结:http://www.cnblogs.com/baiboy/p/wpf.html 篇二:基于OneNote难点突破和批量识别:http://www.cnblog ...

  5. TeamCity : .NET Core 插件

    笔者在<TeamCity : 配置 Build 过程>一文中提到 "TeamCity 内置支持几乎所有的 build 类型".在当今这个软件语言和各种框架飞速发展的时代 ...

  6. 【原创】如何确定Kafka的分区数、key和consumer线程数

    在Kafak中国社区的qq群中,这个问题被提及的比例是相当高的,这也是Kafka用户最常碰到的问题之一.本文结合Kafka源码试图对该问题相关的因素进行探讨.希望对大家有所帮助.   怎么确定分区数? ...

  7. “RazorEngine.Templating.TemplateCompilationException”类型的异常在 RazorEngine.NET4.0.dll 中发生,但未在用户代码中进行处理

    错误信息: "RazorEngine.Templating.TemplateCompilationException"类型的异常在 RazorEngine.NET4.0.dll 中 ...

  8. 第一篇 Entity Framework Plus 之 Audit

    一般系统会有登陆日志,操作日志,异常日志,已经满足大部分的需求了.但是有时候,还是需要Audit 审计日志,审计日志,主要针对数据增,改,删操作数据变化的记录,主要是对数据变化的一个追踪过程.其中主要 ...

  9. Firebug调试js代码

    Firebug功能异常强大,不仅可以调试DOM,CSS,还可以调试JS代码,下面介绍一下调试JS. 1.认识console对象 console对象是Firebug内置的对象,该对象可以在代码中写入,可 ...

  10. Scrapy开发指南

    一.Scrapy简介 Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 可以应用在包括数据挖掘,信息处理或存储历史数据等一系列的程序中. Scrapy基于事件驱动网络框架 Twis ...