js实现图片放大缩小功能后进行复杂排序的方法


Posted in Javascript onNovember 08, 2012

这是一个基于jquery的图片效果,它的作用是:当图片点击变大(变小)时,其它图片按照一定的规则进行排序运动。

首先来看下最终的效果图:
js实现图片放大缩小功能后进行复杂排序的方法

有人可能看到这个会觉得,这有什么难的,这么简单的事,楼主是不是太小提大作了?当你真正去尝试时,你才知道到底有什么难点。 

首先,我们来讲下需求:
1.图片分为大小和小图,大图占四个小图的位置,
2.点击图片放大缩小, 重新排列顺序,
3. 当点击偶数列(2,4)时,它前面的那项将向提出来向后面排列
4.第一个项不能动,点第二个是将占第三四的位置,从后面取第一个小的放置在第二的位置上。
需求就是这样的了,现在难度是否有加大呢,我的思路就是按照这个需求一步步去实现的。代码如下:

var elemArr = $("#old").find("li").get(); 
var arrCol=[0,0,0,0]; 
var defaultSize = 211; 
function setPosition(elemArr,content,oldContent){ 
//alert(elemArr.length) 
if (elemArr.length==0){ 
$(oldContent).remove(); 
animate(content.find("li")); 
var max = Math.max(arrCol[0],arrCol[1],arrCol[2],arrCol[3]) 
$(content).parent().height(max); 
$(content).height(max); 
return; 
} 
var item= $(elemArr.shift()); 
if (item.hasClass("big")){ 
//大 
var min =computeMin(content); 
var x = min.x; 
var y =min.y; 
if (x==defaultSize){ 
var tmp = $("li[x='0'][y='"+y+"']",content); 
if (tmp.hasClass("static")){ 
//第一个 
/* 
arrCol[1]=0; 
x=2*defaultSize; 
if ($("li[x='"+x+"'][y='"+y+"']",content).size()>0){ 
y=parseInt($("li[x='"+x+"'][y='"+y+"']",content).attr("y"))+2*defaultSize; 
} 
arrCol[1]=0; 
*/ 
elemArr=insertSmallArr(elemArr,item); 
setPosition(elemArr,content,oldContent); 
return; 
}else{ 
elemArr=$("li[x='0'][y='"+y+"']",content).get().concat(elemArr); 
//$("li[x='0'][y='"+y+"']",content).remove(); 
x-=defaultSize; 
arrCol[0]-=defaultSize; 
} 
} 
if (x==defaultSize*3){ 
elemArr=$("li[x='"+defaultSize*2+"'][y='"+y+"']",content).get().concat(elemArr); 
//$("li[x='200'][y='"+y+"']",content).remove(); 
x-=defaultSize; 
arrCol[2]-=defaultSize; 
} 
item.attr({"top":y,"left":x}).attr({"x":x,"y":y}); 
if (x==0){ 
arrCol[0]+=defaultSize*2; 
arrCol[1]+=defaultSize*2; 
} 
if (x ==defaultSize*2){ 
arrCol[2]+=defaultSize*2; 
arrCol[3]+=defaultSize*2; 
} 
}else{ 
//小 
var min =computeMin(content); 
var x = min.x; 
var y =min.y; 
item.attr({"top":y,"left":x}).attr({"x":x,"y":y}); if (x==0){ 
arrCol[0]+=defaultSize; 
} 
if (x ==defaultSize){ 
arrCol[1]+=defaultSize; 
} 
if (x ==defaultSize*2){ 
arrCol[2]+=defaultSize; 
} 
if (x ==defaultSize*3){ 
arrCol[3]+=defaultSize; 
} 
} 
$(content).append(item) 
setPosition(elemArr,content,oldContent); 
} 
setPosition(elemArr,$("#news"),$("#old")); 
function insertSmallArr(arr,item){ 
arr = item.get().concat(arr); 
var tmpArr =[]; 
var first =null; 
for (var i=arr.length-1;i>=0 ;i-- ){ 
if (!$(arr[i]).hasClass("big")){ 
first=arr[i]; 
break; 
} 
} 
if (first){ 
tmpArr.push(first); 
} 
for (var i=0,l=arr.length;i<l ;i++ ){ 
if (first !== arr[i]){ 
tmpArr.push(arr[i]); 
} 
} 
return tmpArr; 
} 
function computeMin(content){ 
var arr = $(content).find("li"); 
var miny = Math.min(arrCol[0],arrCol[1],arrCol[2],arrCol[3]) 
var minx= 0; 
if (miny==arrCol[3]){ 
minx=defaultSize*3; 
} 
if (miny==arrCol[2]){ 
minx=defaultSize*2; 
} 
if (miny==arrCol[1]){ 
minx=defaultSize; 
} 
if (miny==arrCol[0]){ 
minx=0; 
} 
return {x:minx,y:miny}; 
} 
$("#main_content").delegate("li","click",function(){ 
if ($(this).index()==0){ 
return false; 
} 
if (!$(this).hasClass("big")){ 
$(this).attr({"h":417,"w":417}) 
}else{ 
$(this).attr({"h":206,"w":206}) 
} 
$(this).toggleClass("big"); 
$(this).parent().hide(); 
var c =$(this).parent().children(); 
c.attr({"x":0,"y":0}); 
arrCol=[0,0,0,0]; 
var tmpArr = c.get(); 
var content = $('<ul></ul>'); 
$("#main_content").append(content); 
setPosition(tmpArr,content,$(this).parent()); 
}) 
$("#addNews").click(function(){ 
var parent = $(this).closest("ul"); 
$(this).parent().after("<li>news</li>"); 
var c = parent.children(); 
var tmpArr = c.get(); 
var content = $('<ul></ul>'); 
$("#main_content").append(content); 
parent.hide(); 
arrCol=[0,0,0,0]; 
setPosition(tmpArr,content, parent); 
}); 
function animate(arr){ 
$(arr).each(function(){ 
$(this).animate({ 
"top":parseInt($(this).attr("top")), 
"left":parseInt($(this).attr("left")), 
"width":parseInt($(this).attr("w")), 
"height":parseInt($(this).attr("h")) 
}) 
}); 
}
Javascript 相关文章推荐
零基础学JavaScript最新动画教程+iso光盘下载
Jan 22 Javascript
window.dialogArguments 使用说明
Apr 11 Javascript
另一个javascript小测验(代码集合)
Jul 27 Javascript
有关于JS辅助函数inherit()的问题
Apr 07 Javascript
如何动态加载外部Javascript文件
Dec 02 Javascript
jQuery Mobile弹出窗、弹出层知识汇总
Jan 05 Javascript
vue数据双向绑定原理解析(get &amp; set)
Mar 08 Javascript
详解ES6系列之私有变量的实现
Nov 21 Javascript
微信小程序之onLaunch与onload异步问题详解
Mar 28 Javascript
详解基于Wepy开发小程序插件(推荐)
Aug 01 Javascript
Javascript之datagrid查询详解
Sep 15 Javascript
JavaScript数组 几个常用方法总结
Nov 11 Javascript
jquery的ajax()函数传值中文乱码解决方法介绍
Nov 08 #Javascript
表头固定(利用jquery实现原理介绍)
Nov 08 #Javascript
Javascript继承(上)——对象构建介绍
Nov 08 #Javascript
异步javascript的原理和实现技巧介绍
Nov 08 #Javascript
找出字符串中出现次数最多的字母和出现次数精简版
Nov 07 #Javascript
jquery 如何动态添加、删除class样式方法介绍
Nov 07 #Javascript
探索Emberjs制作一个简单的Todo应用
Nov 07 #Javascript
You might like
PHP中几个常用的魔术常量
2012/02/23 PHP
php单例模式实现(对象只被创建一次)
2012/12/05 PHP
简单谈谈php中的unicode和utf8编码
2015/06/10 PHP
Apache启动报错No space left on device: AH00023该怎么解决
2015/10/16 PHP
php使用curl实现ftp文件下载功能
2017/05/16 PHP
javascript 流畅动画实现原理
2009/09/08 Javascript
js 模式窗口(模式对话框和非模式对话框)的使用介绍
2014/07/17 Javascript
JS简单实现点击复制链接的方法
2016/08/03 Javascript
Javascript获取图片原始宽度和高度的方法详解
2016/09/20 Javascript
如何制作幻灯片(代码分享)
2017/01/06 Javascript
jQuery插件版本冲突的处理方法分析
2017/01/16 Javascript
超全面的JavaScript开发规范(推荐)
2017/01/21 Javascript
js实现图片加载淡入淡出效果
2017/04/07 Javascript
jQuery实现多张图片上传预览(不经过后端处理)
2017/04/29 jQuery
利用Vue实现移动端图片轮播组件的方法实例
2017/08/23 Javascript
详解javascript常用工具类的封装
2018/01/30 Javascript
JavaScript碎片—函数闭包(模拟面向对象)
2019/03/13 Javascript
react国际化化插件react-i18n-auto使用详解
2020/03/31 Javascript
Javascript实现单选框效果
2020/12/09 Javascript
Python安装Imaging报错:The _imaging C module is not installed问题解决方法
2014/08/22 Python
Python利用Beautiful Soup模块修改内容方法示例
2017/03/27 Python
对pandas中iloc,loc取数据差别及按条件取值的方法详解
2018/11/06 Python
python实现网页自动签到功能
2019/01/21 Python
djang常用查询SQL语句的使用代码
2019/02/15 Python
在Pycharm中使用GitHub的方法步骤
2019/06/13 Python
Python 3 实现定义跨模块的全局变量和使用教程
2019/07/07 Python
解决jupyter notebook显示不全出现框框或者乱码问题
2020/04/09 Python
Python库skimage绘制二值图像代码实例
2020/04/10 Python
洲际酒店集团美国官网:IHG美国
2017/11/16 全球购物
介绍一下grep命令的使用
2015/06/12 面试题
外贸主管求职简历的自我评价
2013/10/23 职场文书
营销总监岗位职责
2014/09/16 职场文书
幼儿园毕业典礼园长致辞
2015/07/29 职场文书
MySQL系列之七 MySQL存储引擎
2021/07/02 MySQL
MybatisPlus EntityWrapper如何自定义SQL
2022/03/22 Java/Android
Redis过期数据是否会被立马删除
2022/07/23 Redis