コード例:
ボタンからドロップダウンするメニューをモーダルの境界線上に展開したいと思います。ご覧のとおり、現在の状態では使用できません。これを達成する方法はありますか?
コード例:
ボタンからドロップダウンするメニューをモーダルの境界線上に展開したいと思います。ご覧のとおり、現在の状態では使用できません。これを達成する方法はありますか?
モーダルはオーバーフローを許可しません。次を使用して修正できます。
.modal { overflow: visible; }
.modal-body { overflow-y: visible; }
この修正によりバグが発生した場合に備えて、クラスを追加して、本当に必要なモーダルにのみこれらのルールを適用することをお勧めします。
オーバーフローを削除できない場合: auto 次のようなことができます
$('.drop-down-inside-modal').on('click' , '.dropdown-toggle', function(event){
var self = $(this);
var selfHeight = $(this).parent().height();
var selfWidth = $(this).parent().width();
var selfOffset = $(self).offset();
var selfOffsetRigth = $(document).width() - selfOffset.left - selfWidth;
var dropDown = self.parent().find('ul');
$(dropDown).css({position:'fixed', top: selfOffset.top + selfHeight , left: 'auto', right: selfOffsetRigth , width: '160px'});
});
function fixDropdownPosition(){
var openDropdownButton = $('.drop-down-inside-modal.open');
if($(openDropdownButton).length){
var selfHeight = $(openDropdownButton).height();
var selfWidth = $(openDropdownButton).width();
var openDropdownButtonOffset = $(openDropdownButton).offset();
var openDropdownButtonOffsetRigth = $(document).width() - openDropdownButtonOffset.left - selfWidth;
var openDropdown = $(openDropdownButton).find('ul');
$(openDropdown).css({position:'fixed', top: openDropdownButtonOffset.top + selfHeight , left: 'auto' , right: openDropdownButtonOffsetRigth, width: '160px'});
};
};
$(".modal-body").unbind("scroll");
$(".modal-body").scroll(function(){
fixDropdownPosition();
});
$( window ).resize(function() {
fixDropdownPosition();
});