2015-10-30 3 views
1

У меня есть сетчатая сетчатая сетка с макетом упаковки, который полностью жидкий. Однако при изменении размера браузера сетка перестраивается. Я бы хотел, чтобы сетка была полностью статичной.Предотвратите переделку сетки кладки

JSFiddle: http://jsfiddle.net/5gL8bz3e/1/

Вот мой CSS:

body { 
    overflow-y: scroll; 
    } 

.grid-item, 
.grid-sizer { 
    width: 5.3125vw; 
    } 

.gutter-sizer { 
    width: 1vw; 
    } 

.grid-item { 
    float: left; 
    height: auto; 
    background: #fff; 
    border: 0px solid #fff; 
    margin-bottom: 0vw; 
    background: none; 
    } 

.grid-item img { 
    width: 100%; 
    height: auto; 
    margin: 0; 
    padding: 0; 
    display: block; 
    } 

.grid-item--width2, .grid-item--width2b { width: 11.625vw; } 
.grid-item--width4 { width: 24.25vw; } 
.grid-item--width6 { width: 36.875vw; } 

.grid { 
    background: lightyellow; 
    width: 75vw; 
    position: relative; 
    left: 12.625vw; 
    top: 12.625vw; 
    margin-top: 0; 
    min-height: 1000px; 
    } 

.stamp { 
    width: 11.625%; 
    height: 100%; 
    position: absolute; 
    top: 0; 
    bottom: 0; 
    background: lightpink; 
} 

.stamp1 { 
    left: 0; 
    } 

.stamp2 { 
    right: 0; 
    } 

HTML:

<div class="grid"> 
    <div class="gutter-sizer"></div> 
    <div class="grid-sizer"></div> 

    <div class="grid-item grid-item--width6"> 
     <img src="http://placehold.it/1180x760"/> 
    </div> 

    <div class="grid-item grid-item--width4"> 
     <img src="http://placehold.it/776x496"/> 
    </div> 

    <div class="grid-item grid-item--width2b"> 
     <img src="http://placehold.it/372x496"/> 
    </div> 

    <div class="grid-item grid-item--width2"> 
     <img src="http://placehold.it/372x232"/> 
    </div> 

    <div class="grid-item grid-item--width1"> 
     <img src="http://placehold.it/170x232"/> 
    </div> 

    <div class="grid-item grid-item--width1"> 
     <img src="http://placehold.it/170x232"/> 
    </div> 

     <div class="grid-item grid-item--width6"> 
     <img src="http://placehold.it/1180x760"/> 
    </div> 

    <div class="grid-item grid-item--width4"> 
     <img src="http://placehold.it/776x496"/> 
    </div> 

    <div class="grid-item grid-item--width2b"> 
     <img src="http://placehold.it/372x496"/> 
    </div> 

    <div class="grid-item grid-item--width2"> 
     <img src="http://placehold.it/372x232"/> 
    </div> 

    <div class="grid-item grid-item--width1"> 
     <img src="http://placehold.it/170x232"/> 
    </div> 

    <div class="grid-item grid-item--width1"> 
     <img src="http://placehold.it/170x232"/> 
    </div> 

     <div class="grid-item grid-item--width6"> 
     <img src="http://placehold.it/1180x760"/> 
    </div> 

    <div class="grid-item grid-item--width4"> 
     <img src="http://placehold.it/776x496"/> 
    </div> 

    <div class="grid-item grid-item--width2b"> 
     <img src="http://placehold.it/372x496"/> 
    </div> 

    <div class="grid-item grid-item--width2"> 
     <img src="http://placehold.it/372x232"/> 
    </div> 

    <div class="grid-item grid-item--width1"> 
     <img src="http://placehold.it/170x232"/> 
    </div> 

    <div class="grid-item grid-item--width1"> 
     <img src="http://placehold.it/170x232"/> 
    </div> 

     <div class="grid-item grid-item--width6"> 
     <img src="http://placehold.it/1180x760"/> 
    </div> 

    <div class="grid-item grid-item--width4"> 
     <img src="http://placehold.it/776x496"/> 
    </div> 

    <div class="grid-item grid-item--width2b"> 
     <img src="http://placehold.it/372x496"/> 
    </div> 

    <div class="grid-item grid-item--width2"> 
     <img src="http://placehold.it/372x232"/> 
    </div> 

    <div class="grid-item grid-item--width1"> 
     <img src="http://placehold.it/170x232"/> 
    </div> 

    <div class="grid-item grid-item--width1"> 
     <img src="http://placehold.it/170x232"/> 
    </div> 

</div> 
+0

Это то, что предназначены для изотопной кладки и компоновки упаковки, перестраивают сетку, чтобы заполнить пробелы. Вместо этого рассмотрите fitRows. – Macsupport

ответ

0

Я думаю, что вариант isResizeBound будет делать только что. По умолчанию это true, но вы можете указать его иначе.

var msnry = new Masonry('.grid', { 
    columnWidth: 200, 
    itemSelector: '.grid-item', 
    isResizeBound: false 
}); 

Для получения более подробной информации см. doc.

+0

Я не знаю, хорошо ли это работает - когда я добавляю его в JSFiddle и изменяю его размер, он разбивает желоб. Я должен также упомянуть, что он, похоже, генерирует макет случайным образом в зависимости от размера экрана. Я хотел бы иметь возможность настроить один макет и не изменять его. –

 Смежные вопросы

  • Нет связанных вопросов^_^