我有两个函数来调整和调整屏幕上元素的高度和宽度。
panelHeight 将目标元素的高度设置为可用的屏幕高度,而 panelWidth 调整元素的宽度。
我的问题:
在第一个函数( panelHeight )完成后,我无法确保第二个函数( panelWidth )触发。如果目标元素很长并且有一个滚动条,它将被 panelHeight 删除,但如果在 panelWidth 触发之前没有这样做,则设置的宽度将被空格关闭由滚动条占据(17px - 计算宽度时仍然存在)。
所以我正在寻找一种只在另一个函数完成后触发函数的方法。类似于回调的排序,但我不确定在下面的for循环中是谁:
panelHeight: function (from) {
var self = this,
o = self.options,
wrap = $('div:jqmData(wrapper="true").ui-page-active').last(),
overthrow = wrap.jqmData("scrollmode") == "overthrow" && $('html').hasClass('ui-splitview-mode'),
blacklist = $('html').hasClass('blacklist'),
// calculationg toolbars
// elements
contents = TARGET_ELEMENT;
if (overthrow) {
for ( var i = 0; i < contents.length; i++){
// calculate values
...
contents.eq(i).css({
"max-height": setH,
"margin-top": blacklist == true ? glbH + lclH : 0,
"margin-bottom": blacklist == true ? glbF + lclF : 0
})
}
} else {
for ( var i = 0; i < contents.length; i++){
// calculate values
...
contents.eq(i).css({
"max-height" : "",
"height": o._iPadFixHeight,
"margin-top": blacklist == true ?
parseFloat( lclH.outerHeight() ) : 0,
"margin-bottom": blacklist == true ?
parseFloat( lclF.outerHeight() ) : 0
})
}
}
// USING THIS NOW, WHICH IS NOT NICE
window.setTimeout(function(){ self.panelWidth(false ); },65)
},
所以我要么遍历推翻if-or-else循环而只需要激活 panelWidth * AFTER *循环结束。
问题:
知道如何摆脱超时并将 panelWidth 函数调用添加到循环结束?我尝试使用 queue ,但这也需要延迟(xxx)。另外我不能在for循环中触发panelWidth。我只需要在高度函数完成后触发一次
修改:
这是可能的:
// calling my panelHeight function like this:
self.panelHeight("source").done(function() {
// call panelWidth:
self.panelWidth();
});
如果是这样,我必须在哪里放 var deferred = Deferred(); ?
解:
得到它的工作。谢谢大家!这是我的解决方案:
调用panelHeight 时,添加done()处理程序
$(document).on('pagechange.fixedHeight', function() {
self.panelHeight("pagechange").done( function() {
self.panelWidth( false )
});
});
在 panelHeight 中,声明延迟并返回已解决();
panelHeight: function (from) {
var deferred = $.Deferred();
... run function
return deferred.resolve();
}
答案 0 :(得分:6)