国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jquery二級導(dǎo)航內(nèi)容均分的原理及實現(xiàn)

2019-11-20 22:24:46
字體:
供稿:網(wǎng)友
這個是去年做過的一個項目中的算法,個人感覺還可以,所以拿出來分享下。

背景:頭部導(dǎo)航二級導(dǎo)航有些內(nèi)容太長,一列的話太過難看,就要分成兩列,要做到按塊盡量均分,排列順序沒有限制。

原理:

1.把各個二級導(dǎo)航做為一個獨(dú)立的,內(nèi)部分成多個塊,算出各塊的高度,升序排列。

2.求出各塊的總高度和,除2得到平均最高的高度。

3.從塊的高度最高的開始,如果高度大于平均高度,則這塊放入A邊,其他的分至B邊。

4.如果小于這個高度,則平均高度變?yōu)闇p去最高高度的值。

5.取剩下最高的高度與平均高度比,如果高度大于平均高度,則這塊放入A邊,其他的分至B邊。

6.循環(huán)3-5直到所有塊都結(jié)束。

這是這個代碼的主要思路,這樣就把一個導(dǎo)航的內(nèi)容分成了平均的兩列。

實現(xiàn):

當(dāng)只有一個塊時,不用比較
復(fù)制代碼 代碼如下:

if (arrs.length <= 1) {
$(obj).css({
width : "150px"
});
return;
}

當(dāng)總高不高于限高時,沒有必要分成兩列:
復(fù)制代碼 代碼如下:

if (sum < limitHeight) {
$(obj).css({
width : "150px"
});
return;
}

原理的實現(xiàn)代碼:
復(fù)制代碼 代碼如下:

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下載
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 泸水县| 昌邑市| 射阳县| 诏安县| 宁夏| 惠州市| 周至县| 中宁县| 玉树县| 潜江市| 临城县| 龙游县| 淮阳县| 龙南县| 古丈县| 韩城市| 永安市| 鲁甸县| 宽城| 麻阳| 乐业县| 偏关县| 繁峙县| 龙口市| 镇宁| 上虞市| 乌兰察布市| 义乌市| 莱州市| 沾益县| 含山县| 宜川县| 通海县| 长宁县| 彭水| 师宗县| 苗栗县| 阜康市| 乐安县| 滕州市| 沭阳县|