我正在使用 Masonry 进行布局。当浏览器的窗口调整大小时,我想在 Masonry 重做布局之前执行一些计算。
到目前为止,我已经能够通过修改 jquery.masonry.js 文件并将回调函数添加到选项来做到这一点。但我更愿意在不修改砌体代码的情况下这样做。
添加的选项如下(砌体初始化):
$container.masonry({
itemSelector : '.grid-element'
, preResizeCallback : doPreResize
, isResizable : true
});
然后doPreResize
做我需要做的任何事情。.js 文件中的修改在resize
函数中(版本 v2.0.110927 中的第 293 行附近):
resize : function() {
//added callback to be called before doing resizing-related code
if (this.options.preResizeCallback)
{
this.options.preResizeCallback(this.element);
}
//rest of code
我想做的是使用isResizable
设置为的选项初始化 Masonry,false
然后半手动触发调整大小,同时保持智能调整大小事件。
是否可以设置“智能调整大小”事件来调用函数,例如resizeLayout
?
function resizeLayout(event) {
//do precalculations
//tell masonry to reorganize layout
$container.masonry();
}
我缺少的是如何设置 resize 事件,使其不会被不断触发,而是以与 Masonry 相同的方式完成 when isResizable
is true
。