我的页面上有一些元素,我一次只能加载5个元素.
我需要做的是使用animate.css为加载的元素设置动画.
为了解释这一点,我创造了这个小提琴:
https://jsfiddle.net/89v781rL/6/
向下滚动以查看“显示更多”按钮并单击它以查看其运行情况.
当我加载更多项目时,元素是动画的,但因为它们是以砌体风格布局,它们的位置不断变化,这不是我想要的.基本上我需要将元素保持在第一个位置并继续添加/加载更多元素.
如果您注释掉以下CSS代码并运行JSFIDDLE,您将看到元素的布局有多好,这也是我希望它们在一次加载5时的样子:
#grid li:nth-child(n+6) {
/*display: none;*/
}
我需要做的是使用animate.css将元素反弹.
这是我的完整代码:
$('#sales').click(function() {
$('#grid li').not(':visible').slice(0,5).slideDown();
$('#grid li').not(':visible').slice(0,5).addClass('animated bounceInUp');
});
主要是因为它对我的项目而言非常庞大和臃肿,并且它在我的项目中也无法正常运行.
有人可以就这个问题提出建议吗?
编辑:
这是另一个失败的尝试:
https://jsfiddle.net/89v781rL/8/
还有这个:
Proposed solution
.
简单地说,你想要的是不可能的.至少不是你如何开始它.
但是,这就是问题:我进入编码的原因(来自设计背景 – 以及我回答你的问题的主要原因)是因为一群网络开发人员告诉我我所做的特定设计,这是不可能的.所以我(重新)进行了搜索和实验,直到我找到了方法.
从那以后,每当我得出这个结论时,我总是把它翻译成:
这是可能的,我只是做错了.
在您的特定情况下,您使用的是“砖石”技术,这种技术并不完全是砖石结构.这是一种名为CSS columns
的列布局技术.从技术角度来看,这就是它的作用:
>计算列的宽度,考虑父总宽度,列数和列装订线
>根据得到的列宽计算内容的总高度
>将内容分成适合列的块,尝试平等分配内容,尊重任何break-inside
声明.请注意属性值的暗示名称:避免,不禁止或禁止.根据内容,此规则并不总是适用.
但是,简而言之,这里是您的2列布局最初呈现的方式:
1 4
2 5
3 6
当您决定添加更多内容时,它将再次执行上述步骤,考虑到更新的内容高度导致:
1 5
2 6
3 7
4
它将计算可能的破坏选项,并将用于导致父元素的最小高度的选项.如果两个或多个结果具有相同的高度,则大多数浏览器将选择使较晚/最后一列更短的浏览器.
如果您的内容在渲染后需要保留到位,那么CSS Columns技术显然不是一种选择.所以你正在研究使用绝对定位的技术.你有很多选择,但值得注意的是(我可能是主观的 – 但是有人真正客观吗?)是:
> Masonry
.它配备了非常方便的stamp
方法,专门针对您的要求而设计(将现有元素粘贴到位,因此添加更多内容不会重新定位现有元素 – 这可能偶尔会发生,具体取决于内容和父级 – 例如,如果你有一个现有的短项目列表,并且你添加了一个非常高的项目,它将导致一列比其他项目更高;如果没有在现有项目上调用标记,它们将被重新定位,以便生成的列具有高度差异最小)
> Isotope
– 我从来没有机会使用它,但我听到了很好的事情.
>所谓的pinterest布局脚本.它是由Evan Sharp编写的,它完全依赖于javascript和绝对定位(就像Masonry一样)但效率非常高.他解释了他是如何做到的in this SO answer
,这是关于这项技术的good tutorial
.如果你不太关心技术部分并且只对果汁感兴趣,我发现了一个名为Bootstrap Waterfall
的轻量级插件,除了上面列出的所有内容外,还有一个生产就绪的可用版本.
到目前为止我写的所有东西都是一点点时间和体面的搜索 – 你会得到的.
剩下的唯一步骤(以及真正的答案)是使用所需的animate.css效果将每个项目动画化为视图.我为布局选择了Bootstrap-waterfall,但您也可以选择任何其他选项.这里是:
// Included waterfall script as it doesn't load from github for everyone
+function(t){"use strict";function i(i){this.$pins=i,this.tasks=[],this.timerId=null,this.deferred=new t.Deferred}function e(t){this.img=t,this.initialWidth=t.width,this.initialHeight=t.height}function n(i){return this.each(function(){var e=t(this),n=e.data("mystist.waterfall"),s="object"==typeof i&&i;n&&"string"!=typeof i&&n.destroy()&&(n=null),n||e.data("mystist.waterfall",n=new o(this,s)),"string"==typeof i&&n[i]()})}var s=s||{now:Date.now||function(){return(new Date).getTime()},throttle:function(t,i,e){var n,o,r,a=null,h=0;e||(e={});var l=function(){h=e.leading===!1?0:s.now(),r=t.apply(n,o),a||(n=o=null)};return function(){var u=s.now();h||e.leading!==!1||(h=u);var c=i-(u-h);return n=this,o=arguments,0>=c||c>i?(a&&(clearTimeout(a),a=null),h=u,a||(n=o=null)):a||e.trailing===!1||(a=setTimeout(l,c)),r}},debounce:function(t,a,h,l=function(){var u=s.now()-a;i>u&&u>=0?n=setTimeout(l,i-u):(n=null,e||(h=t.apply(r,n||(r=o=null)))};return function(){r=this,a=s.now();var u=e&&!n;return n||(n=setTimeout(l,i)),u&&(h=t.apply(r,r=o=null),h}}},o=function(i,e){this.$element=t(i),this.options=t.extend({},o.DEFAULTS,e),this.id=Math.random().toString().slice(2),this.$fakePin=null,this.$container=null,this.$pins=null,this.pinWidth=null,this.imgWidth=null,this.lefts=[],this.tops=[],this.init().calculateWidth().calculatePosition().sail(),t(window).on("resize.mystist.waterfall"+this.id,s.debounce(t.proxy(function(){t(window).off("scroll.mystist.waterfall"+this.id),this.calculateWidth().calculatePosition().ship(r.getLoadedPins.call(this))},this),777))};o.VERSION="0.2.4",o.DEFAULTS={},o.prototype.init=function(){return this.initPins().initAttributes(),this},o.prototype.initPins=function(){var i=this.$element.children().length>0?this.$element.children().remove():t(this.$element.data("bootstrap-waterfall-template"));return i.each(function(){var i=t(this).find("img:eq(0)");i.length>0&&(t(this).data("bootstrap-waterfall-src",i.attr("src")),i.attr("src",""))}),this.$pins=i,o.prototype.initAttributes=function(){return this.$fakePin=this.$pins.first().clone(),this.$container=t("
#waterfall .pin {
width: calc(50% - 4px);
opacity: 0;
animation-duration: 0.75s;
animation-fill-mode: both; }
#waterfall .pin.inView {
opacity: 1;
animation-name: bounceInUp; }
#waterfall .pin.inView.fix {
animation: none; }
#waterfall .pin a {
display: block;
padding: 4px 4px 8px; }
* {
Box-sizing: border-Box; }
.container {
text-align: center; }
.container #waterfall {
max-width: 800px;
margin: 0 auto; }
@keyframes bounceInUp {
from,60%,75%,90%,to {
animation-timing-function: cubic-bezier(0.215,0.61,0.355,1); }
from {
opacity: 0;
transform: translate3d(0,3000px,0); }
60% {
opacity: 1;
transform: translate3d(0,-20px,0); }
75% {
transform: translate3d(0,10px,0); }
90% {
transform: translate3d(0,-5px,0); }
to {
transform: translate3d(0,0); }
}
它的主要优点(以及我选择此路线的原因)是它们在滚动到视图之前对图像进行延迟加载,这意味着您不再需要按钮来加载更多内容.您可以将所有图像放在模板中< script>标签(阅读plugin docs – 滚动到Q& A – 看看它为什么建议添加这样的标记).
我还从animate.css中挑出了BounceInUp动画,因此您无需加载它.
注意CSS需要前缀,如果需要,fiddle
还有SCSS.
作为一般规则,我尽量保持它尽可能轻,特别是在javascript监听器方面(滚动时我只是在监听列表中下一个项目的位置,而不是全部).
旨在作为概念证明,指向正确的方向.
我知道我所做的并不完全是你所要求的(在某种意义上它不允许你在第一次计算后添加更多项目 – 不幸的是,Bootstrap Waterfall目前没有update()或addItems()方法而且我真的认为他们应该添加一个,而不重新计算现有的针脚 –
这已不再适用:Mystist,bootstrap-waterfall.js的作者已回应我的github request
并添加了该方法.我现在通过添加一个添加更多按钮来更新jsFiddle,它按预期工作.从我这里向Mystist大拇指).当然,您可能需要根据项目的具体情况调整脚本,以及如何将新项目引入.在jsFiddle中,我选择创建一个生成新的< script>的函数.模板在运行中随机添加引脚.
无论如何,这个布局遵循以下原则:
>有一个绝对的定位方法来放置你的物品
>加载时隐藏所有项目.使用您想要的效果将可见的动画显示为视图(交错).
>锁定所有可见的,以取消调整大小时的任何动画效果(我使用了修复类).
>在滚动条上放置一个监听器,检查下一个不可见的项目是否已进入视图.在动画结束时动画,并在动画结束后修复它.