I'm trying to make a script to put the elements inside a container into columns. The script works fine until I get to 4 column. I can't see where I'm going wrong. Here's the code, and the demo
var container = '.bar',
children = $(container).children().length,
column = 4,
width = $(container).width() / column - 20;
function columnizer(value) {
var i = 1,
x = Math.ceil(value / column),
z = Math.round(value / column),
y = '<div class="column" />';
$(container).children().slice(0, x).wrapAll(y);
while (i < column) {
if (value % 2 === 0 && z === 1 ) {
$(container).children().slice(i, x * i).wrapAll(y);
i++;
}
else if (value % 2 === 0 && z > 1) {
$(container).children().slice(i, x + i * i).wrapAll(y);
i++;
}
else {
$(container).children().slice(i, x + i).wrapAll(y);
i++;
}
}
}
x,yandzthe problem could pop out easier