2016-09-20 160 views
2

我想用jquery構建一個砌體風格的佈局和位置元素。遍歷元素時,我試圖重置列位置,一旦該行已成爲3列寬,但是這個代碼不工作,我不明白爲什麼jquery砌體風格網格

var rowPos = 0; 

$(document).ready(function(){ 

    $('.box').each(function(ind){ 

    var elementWidth = $(this).width(); 
    var elementHeight = $(this).height(); 

    $(this).css({ 

     left: rowPos +'px' 
    }); 


    if(rowPos >= elementWidth * 2){ 
     rowPos === 0; 

    }else{ 
     rowPos += elementWidth; 
    } 

    console.log(rowPos); 
    }); 

}); 

這導致3列寬其他元素堆疊在第三個頂部。

CSS

body{ 
font-size: 20px; 
} 

.container{ 
position: relative; 
} 

.box{ 
width: 33.333%; 
position: absolute; 
color: #fff; 
text-align: center; 
box-sizing: border-box; 

} 
.box span{ 
margin-top: -1em; 
position: relative; 
top: 50%; 
margin-top: -1em; 
} 

.box1, .box3, .box6, .box8{ 

height: 400px; 

} 

.box2, .box5{ 
height: 600px; 
} 
.box4, .box7{ 
height: 350px; 
} 

.container div:nth-child(odd){ 
background: #2a8d6f; 

} 
.container div:nth-child(even){ 
background: #5b3eac; 

} 

標記

<div class="container"> 
     <div class="box box1"><span>box 1</span></div> 
     <div class="box box2"><span>box 2</span></div> 
     <div class="box box3"><span>box 3</span></div> 
     <div class="box box4"><span>box 4</span></div> 
     <div class="box box5"><span>box 5</span></div> 
     <div class="box box6"><span>box 6</span></div> 
     <div class="box box7"><span>box 7</span></div> 
     <div class="box box8"><span>box 8</span></div> 

    </div> 
+1

請您分享您的HTML和CSS嗎? – vijayP

+0

添加了標記和css。感謝 –

+0

只是出於好奇,如果你正在處理不同大小的'div'盒子,你將如何管理'top'位置? – vijayP

回答

1

我覺得應該是

if(rowPos >= elementWidth * 2){ 
    rowPos = 0; //not rowPos === 0; 

}else{ 
    rowPos += elementWidth; 
} 
+0

當然應該!謝謝你 –

0

請看看這種方法。能夠同時管理箱的頂部位置:

var rowPos = 0; 
 
var counter = 0; 
 
$(document).ready(function() { 
 

 
    $('.box').each(function(ind) { 
 

 
    var elementWidth = $(this).width(); 
 
    var elementHeight = $(this).height(); 
 
    var height = 0; 
 
    var top = 0; 
 
    if (ind >= 3) { 
 
     var topBox = $('.box').eq(ind - 3); 
 
     height = topBox.height(); 
 
     top = topBox.position().top; 
 
    } 
 
    $(this).css({ 
 
     left: rowPos + 'px', 
 
     top: (height + top) + 'px' 
 
    }); 
 

 

 
    if (counter >= 2) { 
 
     rowPos = 0; 
 
     counter = 0; 
 
    } else { 
 
     rowPos += elementWidth; 
 
     counter++; 
 
    } 
 
    }); 
 

 
});
body { 
 
    font-size: 20px; 
 
} 
 
.container { 
 
    position: relative; 
 
} 
 
.box { 
 
    width: 33.333%; 
 
    position: absolute; 
 
    color: #fff; 
 
    text-align: center; 
 
    box-sizing: border-box; 
 
} 
 
.box span { 
 
    margin-top: -1em; 
 
    position: relative; 
 
    top: 50%; 
 
    margin-top: -1em; 
 
} 
 
.box1, 
 
.box3, 
 
.box6, 
 
.box8 { 
 
    height: 400px; 
 
} 
 
.box2, 
 
.box5 { 
 
    height: 450px; 
 
} 
 
.box4, 
 
.box7, 
 
.box9 { 
 
    height: 350px; 
 
} 
 
.container div:nth-child(odd) { 
 
    background: #2a8d6f; 
 
} 
 
.container div:nth-child(even) { 
 
    background: #5b3eac; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script> 
 
<div class="container"> 
 
    <div class="box box1"><span>box 1</span> 
 
    </div> 
 
    <div class="box box2"><span>box 2</span> 
 
    </div> 
 
    <div class="box box3"><span>box 3</span> 
 
    </div> 
 
    <div class="box box4"><span>box 4</span> 
 
    </div> 
 
    <div class="box box5"><span>box 5</span> 
 
    </div> 
 
    <div class="box box6"><span>box 6</span> 
 
    </div> 
 
    <div class="box box7"><span>box 7</span> 
 
    </div> 
 
    <div class="box box8"><span>box 8</span> 
 
    </div> 
 
    <div class="box box9"><span>box 9</span> 
 
    </div> 
 
</div>

+0

是的,這是我要去的方向,雖然說得不那麼雄辯,但它似乎給列之間的一些奇怪的利潤。雖然他們似乎消失時,切換檢查...怪異 –