У меня есть ModalPopupExtender из AjaxControlToolkit, который работает правильно в Firefox, Chrome и IE8, но когда я запускаю его в режиме совместимости IE8, он всплывает за содержимым моей страницы, а не сверху.
Всплывающее окно находится в пользовательском элементе управления, который отображается на главной странице. Я думаю, что происходит, когда он появляется перед содержимым главной страницы, так как содержимое главной страницы (мой заголовок и боковые панели) неактивно, но заполнители содержимого отображаются перед моим всплывающим окном. В сети я нашел решение, в котором предлагалось изменить объявление doctype на главной странице:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
Но у меня уже было это точное объявление, и у меня все еще есть проблема с позиционированием. Вот всплывающий код:
<cc1:ModalPopupExtender ID="ModalPopupExtender1" runat="server"
TargetControlID="lnkbtnDealerID"
PopupControlID="pnlPopup"
BackgroundCssClass="modalBackground"
DropShadow="true"
OkControlID="OkButton"
CancelControlID="CancelButton"
OnOkScript=""
>
</cc1:ModalPopupExtender>
<asp:Panel ID="pnlPopup" runat="server" CssClass="modalPopup" Style="display: none" Width="233px">
<p>Are you sure? Your current shopping cart is valid only for the current Dealer ID. Switching Dealer IDs will reset your cart according to the new Dealer ID chosen.</p>
<br />
<div align="center">
<asp:Button ID="OkButton" runat="server" Text="Ok" />
<asp:Button ID="CancelButton" runat="server" Text="Cancel" />
</div>
</asp:Panel>
и соответствующий CSS:
.popupControl {
background-color: white;
position:absolute;
visibility:hidden;
border-style:solid;
border-color: Black;
border-width: 2px;
}
.modalBackground {
background-color:Gray;
filter:alpha(opacity=70);
opacity:0.7;
}
.modalPopup {
background-color:white;
border-width:1px;
border-style:solid;
border-color:Gray;
padding:3px;
width:250px;
}