大家好,我希望你做得很好。我正在使用同位素,下面你可以看到我写的JavaScript。如果它们是同位素元素,我发现无法将li
元素居中。要了解我的意思,请参阅下面的图片。我已经设法将整个同位素居中放置在屏幕上,但我需要这些元素也居中,而不是只漂浮在左侧。同位素中心元素
让我们开始与我的脚本代码:
<script>
$(document).ready(function(e) {
$(".ullist li").addClass('element-item');
});
</script>
<script>
$(document).ready(function(e) {
// external js: isotope.pkgd.js
// init Isotope
var $grid = $('.grid').isotope({
itemSelector: '.element-item',
//layoutMode: 'fitRows',
});
//$('.grid').isotope({ layoutMode : 'fitRows' });
// filter functions
var filterFns = {
// show if number is greater than 50
numberGreaterThan50: function() {
var number = $(this).find('.number').text();
return parseInt(number, 10) > 50;
},
// show if name ends with -ium
ium: function() {
var name = $(this).find('.name').text();
return name.match(/ium$/);
}
};
// bind filter button click
$('#filters').on('click', 'a', function() {
var filterValue = $(this).attr('data-filter');
// use filterFn if matches value
filterValue = filterFns[ filterValue ] || filterValue;
$grid.isotope({ filter: filterValue });
});
// change is-checked class on buttons
$('.secmenu ul a').each(function(i, buttonGroup) {
var $buttonGroup = $(buttonGroup);
$buttonGroup.on('click', 'a', function() {
$buttonGroup.find('.is-checked').removeClass('is-checked');
$(this).addClass('is-checked');
});
});});
</script>
<script>
$(function(){
var $container = $('.grid'),
$body = $('body'),
colW = 20,
columns = null;
$container.isotope({
// disable window resizing
resizable: true,
masonry: {
columnWidth: colW,
isFitWidth: true
}
});
$(window).smartresize(function(){
// check if columns has changed
var currentColumns = Math.floor(($body.width() -10)/colW);
if (currentColumns !== columns) {
// set new column count
columns = currentColumns;
// apply width to container manually, then trigger relayout
$container.width(columns * colW)
.isotope('reLayout');
}
}).smartresize(); // trigger resize to set container width
});
</script>
基本HTML结构:
<ul class="ullist grid">
<li> ... </li>
<li> ... </li>
<li> ... </li>
<li> ... </li>
</ul>
同位素工作得很好,没有问题(到目前为止)。 这是我目前的布局:
我甚至在这里检查并尝试使用David DeSandro的存储库,但没有成功。所以,请大家可以帮助我实现上面的布局吗? 谢谢大家提前。
是的,但这种方式我不能使用同位素给我的动画效果和过滤我想在同位素代码中实现这种布局 – justme
只是为了提供信息:flex不支持IE9,而且你不需要写flex-direction:row是因为它是默认值。另一种:最常用的方法是给flex-items一个宽度而不是flex-basic。 –