アプリ用に素敵な小さなモーダル メッセージ ウィンドウを作成しましたが、オーバーレイに挿入されているコンテナーの高さを見つけることができないようです。
function load_shipping_message (title, message) {
var left = (($(window).width() / 2) - 300) + 'px';
var height = $(document).height();
var overlay = $('<div id="overlay" style="display:none;height:'+height+'px;"></div>').appendTo($('body'));
var atc = $('<div class="atc-container" style="width:600px;"></div>').appendTo($('#overlay'));
var mess = $('<div class="atc-msg"><div class="success">'+title+'</div><p>'+message+'</p><p class="clearfix"><a class="button" style="float:right;"><span>Close</span></p></div>');
atc.html(mess);
var top = (($(window).height() / 2) - (atc.height() / 2)) + 'px';
atc.css ({
'top': top,
'left': left
});
overlay.fadeIn('slow', function () {
overlay.click (function() {
overlay.fadeOut ('slow', function () {
overlay.remove();
});
});
});
}
上記の atc.height() の値は、コンテンツが含まれていても常に 0 を返します。
atc.height() は常にゼロであるため、メッセージ ボックスの上部をビューポートの中間点に設定するだけです。きちんと中央揃えにしたいだけで、中身の長さによって箱の高さが明らかに違います。
おそらくオーバーレイが非表示になっているためでしょうか?
ありがとう。
-ヴィンス