jquery二级导航内容均分的原理及实现
更新时间:2013年08月13日 16:33:36 作者:
头部导航二级导航有些内容太长,一列的话太过难看,就要分成两列,要做到按块尽量均分,排列顺序没有限制
这个是去年做过的一个项目中的算法,个人感觉还可以,所以拿出来分享下。
背景:头部导航二级导航有些内容太长,一列的话太过难看,就要分成两列,要做到按块尽量均分,排列顺序没有限制。
原理:
1.把各个二级导航做为一个独立的,内部分成多个块,算出各块的高度,升序排列。
2.求出各块的总高度和,除2得到平均最高的高度。
3.从块的高度最高的开始,如果高度大于平均高度,则这块放入A边,其他的分至B边。
4.如果小于这个高度,则平均高度变为减去最高高度的值。
5.取剩下最高的高度与平均高度比,如果高度大于平均高度,则这块放入A边,其他的分至B边。
6.循环3-5直到所有块都结束。
这是这个代码的主要思路,这样就把一个导航的内容分成了平均的两列。
实现:
当只有一个块时,不用比较
if (arrs.length <= 1) {
$(obj).css({
width : "150px"
});
return;
}
当总高不高于限高时,没有必要分成两列:
if (sum < limitHeight) {
$(obj).css({
width : "150px"
});
return;
}
原理的实现代码:
for (var i = arrs.length - 1; i > -1; i--) {
var _h = $(arrs[i]).height();
if (_h < gap) {
gap = gap - _h;
oldArrs.push(arrs[i]);
} else {
newArrs.push(arrs[i]);
}
}
oldArrs,newArrs代表A,B
demo下载
背景:头部导航二级导航有些内容太长,一列的话太过难看,就要分成两列,要做到按块尽量均分,排列顺序没有限制。
原理:
1.把各个二级导航做为一个独立的,内部分成多个块,算出各块的高度,升序排列。
2.求出各块的总高度和,除2得到平均最高的高度。
3.从块的高度最高的开始,如果高度大于平均高度,则这块放入A边,其他的分至B边。
4.如果小于这个高度,则平均高度变为减去最高高度的值。
5.取剩下最高的高度与平均高度比,如果高度大于平均高度,则这块放入A边,其他的分至B边。
6.循环3-5直到所有块都结束。
这是这个代码的主要思路,这样就把一个导航的内容分成了平均的两列。
实现:
当只有一个块时,不用比较
复制代码 代码如下:
if (arrs.length <= 1) {
$(obj).css({
width : "150px"
});
return;
}
当总高不高于限高时,没有必要分成两列:
复制代码 代码如下:
if (sum < limitHeight) {
$(obj).css({
width : "150px"
});
return;
}
原理的实现代码:
复制代码 代码如下:
for (var i = arrs.length - 1; i > -1; i--) {
var _h = $(arrs[i]).height();
if (_h < gap) {
gap = gap - _h;
oldArrs.push(arrs[i]);
} else {
newArrs.push(arrs[i]);
}
}
oldArrs,newArrs代表A,B
demo下载
相关文章
jQuery插件jcrop+Fileapi完美实现图片上传+裁剪+预览的代码分享
这篇文章主要介绍了jQuery插件jcrop+Fileapi完美实现图片上传+裁剪+预览的代码,非常的简单实用,效果也很棒,有需要的小伙伴可以参考下。2015-04-04
如何确保JavaScript的执行顺序 之jQuery.html并非万能钥匙
在上一篇文章《如何确保JavaScript的执行顺序 - 之jQuery.html深度分析》中,我们揭示了jQuery.html函数之所以能在各种浏览器下保持动态JS顺序执行,其秘密在于 – 同步AJAX获取外部JavaScript。2011-03-03
jQuery ajax在GBK编码下表单提交终极解决方案(非二次编码方法)
当jquery ajax在utf-8编码下(页面utf-8,接收utf-8),无任何问题。可以正常post、get,处理页面直接获取正确的内容。2010-10-10
jQuery插件FusionCharts实现的2D面积图效果示例【附demo源码下载】
这篇文章主要介绍了jQuery插件FusionCharts实现的2D面积图效果,结合完整实例形式分析了FusionCharts绘制2D面积图的完整步骤与相关属性设置操作技巧,并附带demo源码供读者下载参考,需要的朋友可以参考下2017-03-03


最新评论