JS实现 类似图片3D效果
其实这样的效果 目前很多网站上都有 其实以前也写过一个 只是当时代码只是为了实现而已,代码很乱,所以现在有业余时间研究了下,其实也并没有什么特殊地方 很类似于左右控制按钮切换图片的思路。效果如下:

可能录制的时候 有点卡 。
具体思路: 1. 首先和左右箭头切换图片思路是一模一样的 点击下一页按钮时候 外层容器left = 一张图片的宽度×当前的索引index 同理 点击上一页按钮也一样 然后加点动画效果改变相对应的宽度和高度 就可以实现。思路其实很简单的。所以就半斤八两就写了一个,希望各位高手包涵啊!所以也没有什么好解释的地方。直接上代码,下面有源码附件 具体的可以看看源码。
HTML代码如下:
<div class="slider">
<a href="javascript:void(0);" class="prev btn"></a>
<div class="scroll">
<ul class="scrollContainer">
<li class="panel">
<a href="" class="inside" target="_blank">
<img width="230" height="288" alt="Alexander McQueen秋季" src="data:images/1.jpg" />
<span>Alexander McQueen秋季1</span>
</a>
</li>
<li class="panel">
<a href="" class="inside" target="_blank">
<img width="230" height="288" alt="Alexander McQueen秋季" src="data:images/2.jpg" />
<span>Gustavsson演绎朋克的性感</span>
</a>
</li>
<li class="panel">
<a href="" class="inside" target="_blank">
<img width="230" height="288" alt="Alexander McQueen秋季" src="data:images/3.jpg" />
<span>Alexander McQueen秋季3</span>
</a>
</li>
<li class="panel">
<a href="" class="inside" target="_blank">
<img width="230" height="288" alt="Alexander McQueen秋季" src="data:images/4.jpg" />
<span>Alexander McQueen秋季4</span>
</a>
</li>
<li class="panel">
<a href="" class="inside" target="_blank">
<img width="230" height="288" alt="Alexander McQueen秋季" src="data:images/5.jpg" />
<span>Alexander McQueen秋季5</span>
</a>
</li>
<li class="panel">
<a href="" class="inside" target="_blank">
<img width="230" height="288" alt="Alexander McQueen秋季" src="data:images/6.jpg" />
<span>Alexander McQueen秋季6</span>
</a>
</li>
<li class="panel">
<a href="" class="inside" target="_blank">
<img width="230" height="288" alt="Alexander McQueen秋季" src="data:images/7.jpg" />
<span>Alexander McQueen秋季7</span>
</a>
</li>
</ul>
</div>
<a href="javascript:void(0);" class="next btn"></a>
</div>
CSS代码如下:
<style>
*{margin:;padding:;list-style-type:none;}
a,img{border:;}
body{font:12px/180% Arial, Helvetica, sans-serif, "新宋体";}
a{color:#000;outline:none;text-decoration:none;}
a:hover{text-decoration:underline;}
/* slider */
.slider{width:730px;height:312px;overflow:hidden;position:relative;margin:20px auto 0;}
.scroll{float:left;display:inline;width:660px;height:312px;margin-left:30px;overflow:hidden;position:relative;}
.scrollContainer{position: relative;left:0px;}
.scrollContainer .current .inside{width:230px;height:288px;} .scrollContainer .panel{width:170px;height:235px;float: left;padding-right:30px;overflow:hidden;} .panel .inside{display:block;position:relative; }
.inside img{height:100%;width:100%;}
.scroll li .inside span{
position:absolute;
bottom:0px;
left:16px;
width:197px;
height:37px;
line-height:37px;
display:none;
background-color:#c69;
font-size:14px;color:#FFF;
text-align:center;
z-index:;
}
.scroll li.current .inside span{display:block;} .slider a.btn{background:url('images/index.png') no-repeat;}
.slider a.btn{float:left;margin-top:92px;width:20px; height:39px; } .slider a.prev{background-position:0 -61px;}
.slider a.prev:hover{background-position:0 -102px;} .slider a.next{right:;background-position:-50px -61px;}
.slider a.next:hover{background-position:-50px -102px;} .scrollContainer .current {width:230px;height:312px;}
</style>
JS代码如下:
/*
* JS 3D效果
* @author tugenhua
* @date 2013-11-28
* @email 879083421@qq.com
*/
function LeftAndRight(options) { this.config = {
container : '.slider', // 最外层容器
scrollContainer : '.scrollContainer', // 外层容器ul
prevBtn : 'prev', // 上一页按钮
nextBtn : 'next', // 下一页按钮
currentCls : 'current', // 当前的类名
addItemWidth : 70, // 中间突出增加的宽度
changeBeforeWH : {width:'170px',height:'235px'}, // 改变前的宽度和高度
changeAfterWH : {width:'230px',height:'312px'}, // 改变后的宽度和高度
callback : null // 每次点击后的回调函数 @param 当前的第几个
}; this.cache = {
curIndex : 0 // 保存当前li的索引
}; this.init(options);
} LeftAndRight.prototype = { constructor: LeftAndRight, init: function(options) {
this.config = $.extend(this.config, options || {});
var self = this,
_config = self.config,
_cache = self.cache; // 初始化计算ul的宽度
self._calculateUlWidth(); // 所有事件
self._bindEnv();
},
_calculateUlWidth: function(){
var self = this,
_config = self.config,
_cache = self.cache; if($(_config.scrollContainer) && $(_config.scrollContainer + ' li').length > 0){ $(_config.scrollContainer).each(function(index,item){ var liWidth = $('li',item).outerWidth(),
liLen = $('li',item).length; // 初始化时候 让中间的li 增加class current
var centerLi = $('li',item)[_cache.curIndex + 1]; $(centerLi).animate({'width':_config.changeAfterWH.width,'height':_config.changeAfterWH.height}); $(item).css("width",liWidth * liLen + _config.addItemWidth);
}); }
},
_bindEnv: function() {
var self = this,
_config = self.config,
_cache = self.cache; if($(_config.container).length > 0) { $(_config.container).each(function(index,item){ // 事件代理
$(item).unbind('click');
$(item).bind('click',function(e){ var target = e.target; // 目前点击元素小于3个 用if else判断 否则的话 建议用switch
if($(target).hasClass(_config.prevBtn)){
self._prev($(this)); }else if($(target).hasClass(_config.nextBtn)){
self._next($(this)); }else { }
});
});
}
},
_prev: function(container){
var self = this,
_config = self.config,
_cache = self.cache; if(_cache.curIndex < 1) {
return;
}
_cache.curIndex--;
self._publicMethod(_cache.curIndex,container); },
_next: function(container){
var self = this,
_config = self.config,
_cache = self.cache; _cache.curIndex++; $(_config.scrollContainer).each(function(index,item){
var liLen = $('li',item).length;
if(_cache.curIndex >= liLen -2) {
_cache.curIndex = liLen -3;
return;
}
self._publicMethod(_cache.curIndex,container);
}); },
_publicMethod: function(curIndex,container){
var self = this,
_config = self.config,
_cache = self.cache; $(_config.scrollContainer,container).each(function(index,item){
var liWidth = $('li',item).outerWidth(),
liHeight = $('li',item).outerHeight(),
liLen = $('li',item).length; self._prevNextProcess({ulContainer:item,liW:liWidth,liH:liHeight,liLen:liLen,index:curIndex});
});
},
_prevNextProcess: function(cfg) {
var self = this,
_config = self.config,
_cache = self.cache; var curLi = $('li',cfg.ulContainer)[cfg.index + 1];
$('li',cfg.ulContainer).each(function(index,item){
$(item).css({'width':_config.changeBeforeWH.width,'height':_config.changeBeforeWH.height});
});
$(curLi).animate({'width':_config.changeAfterWH.width,'height':_config.changeAfterWH.height});
$(cfg.ulContainer).animate({'left':-cfg.index * cfg.liW},function(){ });
var cindex = cfg.index + 2;
_config.callback && $.isFunction(_config.callback) && _config.callback(cindex); }
};
// 初始化代码
$(function(){
new LeftAndRight({
callback: function(index){
//console.log(index);
}
});
});
JS实现 类似图片3D效果的更多相关文章
- 网页3D效果库Three.js初窥
网页3D效果库Three.js初窥 背景 一直想研究下web页面的3D效果,最后选择了一个比较的成熟的框架Three.js下手 ThreeJs官网 ThreeJs-github; 接下来我会陆续翻译 ...
- 使用Three.js网页引擎创建酷炫的3D效果的标签墙
使用Three.js引擎(这是开源的webgl三维引擎,gitgub)进行一个简单应用. 做一个酷炫的3d效果的标签墙(已经放在我的博客首页,大屏幕可见), 去我的博客首页看看实际效果 www.son ...
- WPF 图片浏览 伪3D效果
原文:WPF 图片浏览 伪3D效果 首先上效果图: 因项目要求,需要把图片以"好看"."炫"的效果展示出来,特地研究了一下WPF关于3D方面的制作,奈何最终成果 ...
- css3 3D效果
css3 3D变形 transfrom初学 这个礼拜学了css3 3d,感觉到css无穷的魅力,可以通过几个特定的代码符号创建出3D效果的页面. ___ 透视 一个元素需要一个透视点才能激活3D空间, ...
- 一篇文章搞定css3 3d效果
css3 3d学习心得 卡片反转 魔方 banner图 首先我们要学习好css3 3d一定要有一定的立体感 通过这个图片应该清楚的了解到了x轴 y轴 z轴是什么概念了. 首先先给大家看一个小例子: 卡 ...
- CSS3新特性2D、3D效果讲解
希望这篇博客可以对你有所帮助,如果有什么技术上的问题,希望我们可以做进一步的交流,如果你觉得我哪里阐述的不正确或者你有更好的更透彻的理解,也可以联系我,我在这里随时等着你. 对于css/html是每个 ...
- 使用webgl(three.js)搭建一个3D智慧园区、3D建筑,3D消防模拟,web版3D,bim管理系统——第四课
序:这段时间忙于奔波,好久没有更新了,今天更新一下,继续上节课的完善讲解,算是对前段时间的一个总结吧.披星戴月的时光也算有点应用效果了. 对于webgl(three.js)性能这一块我在上节课< ...
- CSS3,3D效果轮播图
---恢复内容开始--- 大家还记得我昨天的3D拖拽立方体吗??我昨天还说过css还可以做轮播图,所以咱们今天就写一下,css的轮播图吧! ....这个轮播图主要是用CSS3里的transform的旋 ...
- echart.gl.js实现动态3D柱状图
echart.gl.js实现动态3D柱状图 一.总结 一句话总结:演示页面的源代码里面一定有所需的所有的js. 二.[js实践篇]——echart.gl.js实现动态3D柱状图 前言 本公司的项目需求 ...
随机推荐
- XJad反编译工具
XJad反编译工具 我们写的java文件,编译后就会生成相应的字节码文件,也就是.java文件经过编译以后生成.class文件 现在,假设我们现在存在这样一个问题:就是我们想自己动手验证注释会不会被编 ...
- Flask中request参数
首先要明确一件事,Request这是个对象,不管使用PHP还是python还是什么java语言,虽然request这个对象可能叫的名字不一样,(在其他语言中可能叫什么HttpRequest),但是原理 ...
- [World Final 2016] Branch Assignment
链接 PDF bzoj 先求出正置边和反置边时b+1到前b个点的最短路dis[0/1][x](x∈[1,b]), 令D[x]=dis[0][x]+dis[1][x] 然后分组后每个x对代价的贡献为D[ ...
- onkeydown小练习
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- [原创.数据可视化系列之八]使用等d3进行灰度图转伪彩色
对灰度图进行彩色化是数据可视化中常见的需求,使用d3在客户端比较容易实现,本文使用d3生成图片,并显示: 代码如下: 代码中首先下载数据文件,然后设定d3的色带信息,生成一个空白的canvas元素,并 ...
- 安装Wamp时出现无法启动此程序,因为计算机中丢失MSVCR110.dll
一.问题描述 安装Wamp时出现无法启动此程序,因为计算机中丢失MSVCR110.dll 二.解决方法 首先进入 http://www.microsoft.com/zh-CN/download/det ...
- Lambda表达式 For Android
Lambda简介 A lambda expression is a block of code with parameters. lambda表达式是带参数的代码块. 虽然看着很先进,其实Lambda ...
- 安装 Java 开发工具包JDK(Windows版本)
前言: 进行java开发,首先要安装jdk,安装完成之后,还需要进行环境变量配置,以下就介绍一下具体步骤 具体步骤: 1.进入官网(https://www.oracle.com/technetwork ...
- 2018-10-27 22:44:33 c language
2018-10-27 22:44:33 c language 标准的C语言并不支持上面的二进制写法,只是有些编译器自己进行了扩展,才支持二进制数字.并不是所有的编译器都支持二进制数字,只有一部分编译 ...
- eclipse中svn插件的工程不能与svn资源库同步的解决方法
eclipse中svn插件的工程不能与svn资源库同步的解决办法 最近几天自己的工程与资源库同步总是出现问题,重启机器后发现资源库丢失了,无法进行同步. 解决办法如下: 1.右键工程---->选 ...