砌体无限滚动附加html5视频重叠
我目前正在使用imagesLoaded
库检查图片是否已加载,然后调用masonry
。
但它没有使用html5视频标签,因为这些视频相互重叠。
所以我更改了从masonry
拨打document.ready
到window.load
,并在初次加载时删除了对imagesLoaded
的呼叫,即
从这个
$(document).ready(function(){
var $container = $('#media');
// layout Masonry again after all images have loaded
$container.imagesLoaded( function() {
$container.masonry({
"columnWidth": "." + "col-sm-2",
itemSelector: '.item',
gutter: 0,
});
$('.item').css('opacity', '1.0');
});
});
到这个
$(window).load(function(){
var $container = $('#media');
$container.masonry({
"columnWidth": "." + "col-sm-2",
itemSelector: '.item',
gutter: 0,
});
$('.item').css('opacity', '1.0');
});
现在html5 videos
masonry
中的initial load
没有重叠,并且在网页首次加载即infinite-scroll
时完美呈现,
但是因为我也在使用images/videos
在滚动页面上添加更多masonry
,所以当新视频被添加到容器时它们正在重叠,这种行为是由{{1}的早期运行引起的在加载所有视频元素之前,imagesloaded
无法检查videos loaded
。
这是代码。
$(document).ready(function(){
var $container = $('#media');
var no_more_media = "<?= Lang::get('lang.no_more_to_load') ?>";
var loading_more_media = "<?= Lang::get('lang.loading_more_media') ?>";
$container.imagesLoaded(function(){
$container.masonry();
});
$container.infinitescroll({
loading: {
finished: undefined,
finishedMsg: "<p>" + no_more_media + "</p>",
img: "",
msg: null,
msgText: "<div class='loading'><i></i><i></i><i></i></div><p>" + loading_more_media + "</p>",
selector: null,
speed: 'fast',
start: undefined,
},
navSelector : "ul.pagination",
// selector for the paged navigation (it will be hidden)
nextSelector : "ul.pagination a:first",
// selector for the NEXT link (to page 2)
itemSelector : ".container #media .item",
animate: false,
bufferPx: 160,
},
function( newElements ) {
// hide new items while they are loading
//var $newElems =
$.each($(newElements), function(index, value){
item_click_events($(value));
});
$( newElements ).css({ opacity: 0 });
$(newElements).imagesLoaded(function(){
var $newElems = $( newElements );
$newElems.animate({ opacity: 1 });
$container.masonry( 'appended', $newElems, true);
}
);
});
});
我也尝试在上面的代码中将document.ready
更改为window.load
,并完全删除imagesloaded
,但它不能与infinitescroll
一起使用。,
e.g。修改后的代码
$(window).load(function(){
var $container = $('#media');
var no_more_media = "<?= Lang::get('lang.no_more_to_load') ?>";
var loading_more_media = "<?= Lang::get('lang.loading_more_media') ?>";
$container.masonry();
$container.infinitescroll({
loading: {
finished: undefined,
finishedMsg: "<p>" + no_more_media + "</p>",
img: "",
msg: null,
msgText: "<div class='loading'><i></i><i></i><i></i></div><p>" + loading_more_media + "</p>",
selector: null,
speed: 'fast',
start: undefined,
},
navSelector : "ul.pagination",
// selector for the paged navigation (it will be hidden)
nextSelector : "ul.pagination a:first",
// selector for the NEXT link (to page 2)
itemSelector : ".container #media .item",
animate: false,
bufferPx: 160,
},
function( newElements ) {
// hide new items while they are loading
//var $newElems =
$.each($(newElements), function(index, value){
item_click_events($(value));
});
$( newElements ).css({ opacity: 0 });
var $newElems = $( newElements );
$newElems.animate({ opacity: 1 });
$container.masonry( 'appended', $newElems, true);
});
});
我可以通过指定视频宽度和高度来解决这个重叠问题,但作为其响应式设计,指定视频宽度和高度会破坏响应性。
所以我的问题是,
是否有任何js库simmilar到imagesloaded确保所有视频都加载,然后我可以打电话给砌体?
或者如何确保视频不会overlapped
上的infinitescroll
?
更新1:
我尝试过很多技巧,对于infinitescroll
$(newElements).load(function(){
var $newElems = $( newElements );
$newElems.animate({ opacity: 1 });
$container.masonry( 'appended', $newElems, true);
});
在pagescroll之后不会加载新内容。
$(window).load(function(){
var $newElems = $( newElements );
$newElems.animate({ opacity: 1 });
$container.masonry( 'appended', $newElems, true);
});
在pagescroll之后不会加载新内容。
var $newElems = $( newElements );
$newElems.animate({ opacity: 1 });
$container.masonry( 'appended', $newElems, true);
重叠视频内容
所以我想早点调用infinite-scroll
并将container.masonry
放慢3秒,现在效果很好。但仍在等待正确的解决方案。
e.g。
bufferPx: 700,
setTimeout(function(){
var $newElems = $( newElements );
$newElems.animate({ opacity: 1 });
$container.masonry( 'appended', $newElems, true);
}, 3000);
以上是将运行的砖石延迟3秒。
我尝试为window.load
寻找类似div
的内容,但没有,所以我最好的选择是检查是否所有videos
和images
都已加载,然后致电masonry
infinite-scroll
添加了工作演示http://plnkr.co/edit/46YzHBJ7eFAXfsPqZB1q 您可以通过单击“运行”并向下滚动来查看问题。
答案 0 :(得分:5)
看起来你可以通过等待视频
的loadeddata事件来修复它这是基本的想法:
function waitForvidLoad(vids, callback) {
/* if no videos i.e. mobile mode only gifs and jpgs then call callback else masonry breaks.*/
if(vids.length === 0){
callback();
}
var vidsLoaded = 0;
vids.on('loadeddata', function() {
vidsLoaded++;
if (vids.length === vidsLoaded) {
callback();
}
});
}
var $container = $('#container');
var vids = $('#container').find('video');
waitForvidLoad(vids, function() {
$container.imagesLoaded(function() {
$container.masonry({
itemSelector: '.box',
columnWidth: 100
});
});
这里的工作人员: http://plnkr.co/edit/jXJ7oFxF3sFWBAJuBqdQ?p=preview