我在我的aspx页面中应用于面板的样式中定义了以下css。
max-height: 70%; overflow: auto;
max-width: 70%; overflow: auto;
在Mozilla中,我可以调整浏览器窗口的大小,当浏览器窗口变得太小而无法包含面板的完整内容时,面板将正确显示滚动条。这很有效。
在IE8中,max-height css的优先级高于max-width css。
例如:
1)当垂直放大浏览器窗口时,宽度滚动条将在面板底部正确显示。
2)当水平缩小浏览器窗口时,高度滚动条将在面板底部正确显示。
3)当浏览器窗口垂直变小时,宽度滚动条将在面板底部正确显示,但如果我继续使浏览器窗口水平变小,则会出现高度滚动条,但是宽度滚动条消失。如果我使浏览器窗口足够长以容纳面板的高度,则会再次出现宽度滚动条。
如何让IE8在适当时显示滚动条而不仅仅是高度?这在Firefox中正常工作。
这是一个示例页面,它与我的主页面中存在的问题完全相同。单击“显示弹出窗口”,然后尝试使浏览器屏幕变小。您将看到弹出滚动条的行为与上述相同。
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="css.aspx.cs" Inherits="Sandbox.css" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title></title>
<style type="text/css">
.Background
{
filter: Alpha(Opacity=40);
opacity: 0.4;
background-color: #CCCC99;
z-index:1000;
}
.Popup
{
border: solid 1px #c0c0c0;
background:#FFFFFF;
padding: 0px 10px 10px 10px;
position:absolute;
padding-top: 10px;
max-height: 90%; overflow: auto;
max-width: 90%; overflow: auto;
}
</style>
</head>
<body>
<form id="form1" runat="server">
<asp:scriptmanager ID="Scriptmanager1" runat="server"></asp:scriptmanager>
<asp:Button ID="Button1" runat="server" Text="Show Popup" />
<asp:panel ID="Panel1" runat="server" ScrollBars="Auto" CssClass="Popup">
<table>
<tr>
<td>
<asp:Label ID="Label1" runat="server" Text="Label1"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox2" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label2" runat="server" Text="Label2"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox3" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox6" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label3" runat="server" Text="Label3"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox4" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox5" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label4" runat="server" Text="Label4"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox7" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox8" runat="server"></asp:TextBox>
</td>
</tr>
</table>
<asp:Button ID="Button2" runat="server" Text="Ok" />
<asp:Button ID="Button3" runat="server" Text="Cancel" />
</asp:panel>
<ajaxToolKit:ModalPopupExtender runat="server" TargetControlID="Button1" PopupControlID="Panel1"
BackgroundCssClass="Background" OkControlID="Button2" CancelControlID="Button3" />
<table>
<tr>
<td>
<table>
<tr>
<td>
<asp:Label ID="Label5" runat="server" Text="Label1"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox9" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox10" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label6" runat="server" Text="Label2"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox11" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox12" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label7" runat="server" Text="Label3"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox13" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox14" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label8" runat="server" Text="Label4"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox15" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox16" runat="server"></asp:TextBox>
</td>
</tr>
</table>
</td>
<td>
<table>
<tr>
<td>
<asp:Label ID="Label9" runat="server" Text="Label1"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox17" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox18" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label10" runat="server" Text="Label2"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox19" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox20" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label11" runat="server" Text="Label3"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox21" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox22" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label12" runat="server" Text="Label4"></asp:Label>
</td>
<td>
<asp:TextBox ID="TextBox23" runat="server"></asp:TextBox>
</td>
<td>
<asp:TextBox ID="TextBox24" runat="server"></asp:TextBox>
</td>
</tr>
</table>
</td>
</tr>
</table>
</form>
</body>
</html>
代码隐藏:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace Sandbox
{
public partial class css : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
}
}
答案 0 :(得分:0)
尝试将overflow: auto;
更改为overflow: scroll;
答案 1 :(得分:0)
当没有max-width
或max-height
设置时,IE8在理解width
和height
时遇到问题。从你的问题和你的代码来看,我认为你更喜欢而不是来使用这些属性,但在这种情况下,如果你想让它在IE8中运行,你可能没有选择。
尝试使用IE8特定的@media
查询:
@media \0screen {
.Popup {
height: 500px;
width: 500px;
}
}
或者,将width
和height
属性放在类中,并将值\9
附加到目标IE6及更高版本:
.Popup
{
border: solid 1px #c0c0c0;
background:#FFFFFF;
padding: 0px 10px 10px 10px;
position:absolute;
padding-top: 10px;
height: 500px\9;
width: 500px\9;
max-height: 90%; overflow: auto;
max-width: 90%; overflow: auto;
}