おそらく、ここで石工の「兄貴分」アイソトープを見るべきです。特定の順序で並べ替えられているか、特定の順序で固定されている要素があり、それらが単一の列幅よりも広い場合、ブラウザーの幅が狭いと列が「ブロック」される可能性があることに注意してください。
編集多分このフィドルはそれをもう少しよく説明しています。それを見て、div の数字を観察すると、次の組積造要素 (赤い要素 5) は、要素 4 の後に来る必要があるため、白い正方形に収まらない可能性があることがわかります。つまり、最終的には 3 行しか適合しないため、空白のギャップが生じます。おそらく、Isotope の shuffle や reLayout メソッドを使用して、要素を厳密な順序で並べることを犠牲にすることができますか? あなたの問題のjsfiddleが最善です。
<article>
<div class="tile blue"><p>1</p></div>
<div class="tile black"><p>2</p></div>
<div class="tile tall yellow"><p>3</p></div>
<div class="tile grey"><p>4</p></div>
<div class="tile wide red"><p>5</p></div>
<div class="tile green"><p>6</p></div>
<div class="tile grey"><p>7</p></div>
<div class="tile blue"><p>8</p></div>
<div class="tile green"><p>9</p></div>
</article>
$('article').isotope({
itemSelector : '.tile',
masonry: {
columnWidth: 100
}
});
article .tile {
display: block;
float: left;
box-sizing: border-box;
width: 100px;
height: 100px;
font-size: 3em;
font-weight: 700;
padding: 0 6px;
color: #fff;
text-shadow: -1px 0 black, 0 1px black, 1px 0 black, 0 -1px black;
border:1px dotted black;
}
article .tile.wide {
width: 200px;
}
article .tile.tall {
height: 200px;
}
.tile.yellow { background: yellow; }
.tile.red { background: red; }
.tile.blue { background: blue; }
.tile.black { background: black; }
.tile.grey { background: grey; }
.tile.green { background: green; }