JS 阶段练习~ 仿flash的图片轮换效果
结合了所学的简单运动框架~ 做这样一个综合小实例~~
-------------------------主要问题:
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的图片轮换效果的更多相关文章
- 仿FLASH的图片轮换效果
css布局代码(test.css): body { background: #ccc;} ul { padding: 0; margin: 0;} li { list-style: none;} im ...
- 仿flash实现图片轮换播放
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- jQuery仿迅雷图片轮换效果
jQuery仿迅雷图片轮换效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "ht ...
- Jquery实现图片轮换效果
最近在看jquery书时,看到一个比较有趣的东西:图片轮换.这里和大家分享下我看完后写的一个demo.实现图片轮换要完成三部分模块:html部分.css部分.jqury部分.下面分步详细说明.1.ht ...
- Magnifier.js - 支持鼠标滚轮缩放的图片放大镜效果
Magnifier.js 是一个 JavaScript 库,能够帮助你在图像上实现放大镜效果,支持使用鼠标滚轮放大/缩小功能.放大的图像可以显示在镜头本身或它的外部容器中.Magnifier.js 使 ...
- jquery带小图的图片轮换效果
右边显示大图,左边显示小图 <style> ul{ list-style:none; padding:0px; margin:0px;} li{ list-style:none; padd ...
- 仿flash的文字动画效果
.tips{ font-size: 24px; font-family: sans-serif; font-weight: 600; text-shadow: 1px 1px #ffb700; col ...
- DeWeb : 制作图片轮换效果
演示:http://www.web0000.com/slide.dw源代码:http://www.web0000.com/media/source/slide.zip一.新建一个DLL二.除第一行外, ...
- 使用纯生js实现图片轮换
效果图预览. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...
随机推荐
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(6)-Unity 依赖注入
系列目录 前言 为了符合后面更新后的重构系统,文章于2016-11-1日重写 本节重构一下代码,采用IOC控制反转,也就是依赖注入 您可以访问http://unity.codeplex.com/rel ...
- 计算机程序的思维逻辑 (41) - 剖析HashSet
上节介绍了HashMap,提到了Set接口,Map接口的两个方法keySet和entrySet返回的都是Set,本节,我们来看Set接口的一个重要实现类HashSet. 与HashMap类似,字面上看 ...
- Java集合专题总结(1):HashMap 和 HashTable 源码学习和面试总结
2017年的秋招彻底结束了,感觉Java上面的最常见的集合相关的问题就是hash--系列和一些常用并发集合和队列,堆等结合算法一起考察,不完全统计,本人经历:先后百度.唯品会.58同城.新浪微博.趣分 ...
- golang 使用 iota
iota是golang语言的常量计数器,只能在常量的表达式中使用. iota在const关键字出现时将被重置为0(const内部的第一行之前),const中每新增一行常量声明将使iota计数一次(io ...
- [解决方案]CREATE DATABASE statement not allowed within multi-statement transaction.
CREATE DATABASE statement not allowed within multi-statement transaction. 刚开始报这个错误的时候,我上度娘搜了一下. 别人是在 ...
- 【Java每日一题】20161230
// 20161229问题解析请点击今日问题下方的"[Java每日一题]20161230"查看(问题解析在公众号首发,公众号ID:weknow619)package Dec2016 ...
- CXF:根据werservice代码生成WSDL(转)
原文:http://hongyegu.iteye.com/blog/619147,谢谢! import org.apache.cxf.tools.java2ws.JavaToWS; import ne ...
- Hibernnate延迟加载策略(这么详细你还看不懂)
好久没有认真写过博客了,今天就好好的写一篇吧!!!!!!!!! 当Hibernate 从数据库中加载某个对象(例如:Dept对象)时,如果同时自动加载所有的关联的某个对象(例如:Emp对象),而程序实 ...
- canvas贝塞尔曲线
贝塞尔曲线 Bézier curve(贝塞尔曲线)是应用于二维图形应用程序的数学曲线. 曲线定义:起始点.终止点.控制点.通过调整控制点,贝塞尔曲线的形状会发生变化. 1962年,法国数学家Pierr ...
- win10家庭版查看已连接wifi密码
点击屏幕右下角无线网路图标. 点击网络设置. 完成.