当通过VS 2010在dev服务器上运行时,所有CSS都会正确显示。我发布了使用IIS 7赢取服务器2008 r2,当我在IE 9中打开时,内联块不起作用,渐变不起作用,并且盒阴影不起作用。它剥离了大部分的CSS格式,我在firefox中加载了相同的页面,它看起来与在开发服务器下的IE 9中的相同。代码如下: CSS文件:
body {
}
#opsChartContainer
{
background: #FFFFFF;
margin: auto;
width: 600px;
padding-top: 15px;
font-family: helvetica, arial, sans-serif;
display: inline-table;
}
#oldestActiveCon
{
background: #FFFFFF;
margin: auto;
width: 300px;
padding-top: 15px;
font-family: helvetica, arial, sans-serif;
display: inline-table;
}
#incVolumeCon
{
background: #FFFFFF;
margin: auto;
width: 700px;
padding-top: 15px;
font-family: helvetica, arial, sans-serif;
display: inline-table;
}
#reqSLACon
{
background: #FFFFFF;
margin: auto;
width: 400px;
padding-top: 15px;
font-family: helvetica, arial, sans-serif;
display: inline-table;
}
h1
{
background: #e3e3e3;
background: -moz-linear-gradient(top, #fcfdfe, #8bb7e3);
background: -webkit-gradient(linear, left top, left bottom, from(#fcfdfe), to(#8bb7e3));
padding: 10px 20px;
margin-left: -20px;
margin-top: 0;
position: relative;
width: 70%;
-moz-box-shadow: 1px 1px 3px #292929;
-webkit-box-shadow: 1px 1px 3px #292929;
box-shadow: 3px 3px 3px #292929;
-ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#fcfdfe, endColorstr=#8bb7e3)";
color: #454545;
text-shadow: 0 1px 0 white;
font-size: small;
font-weight: bold;
}
h2
{
background: #dde3d5;
padding: 10px 20px;
margin-left: 5px;
margin-top: 10px;
position: relative;
-moz-box-shadow: 1px 1px 3px #292929;
-webkit-box-shadow: 1px 1px 3px #292929;
box-shadow: 3px 3px 3px #b5baae;
color: #454545;
text-shadow: 0 1px 0 white;
font-size: small;
font-style: normal;
}
.mGrid {
width: 100%;
margin: 5px 0 10px 0;
border: solid 1px #525252;
border-collapse:collapse;
}
.mGrid td {
padding: 2px;
}
.header
{
padding: 4px 2px;
color: #ffffff;
background: #4289c6 url('../grd_head.png') repeat-x top;
}
.alt
{
background: #FFFFFF url('../grd_alt.png') repeat-x top;
font-size: smaller;
font-family: Arial;
font-style: normal;
}
.rst
{
background: #FFFFFF url('../grd_firstt.png') repeat-x top;
font-size: smaller;
font-family: Arial;
font-style: normal;
}
ul#testy li
{
list-style-type: none;
display: inline-block;
vertical-align: top;
padding-left: 50px;
}
ASPX前端:
<%@ Page Title="" Language="C#" MasterPageFile="~/Site1.Master" AutoEventWireup="true" CodeBehind="test.aspx.cs" Inherits="test.test" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="server">
<div id="opsChartContainer"><h1>TEXT</h1><h2>FLASHFILE</h2></div>
<div id="oldestActiveCon"><h1>TEXT</h1>
<h2>
<asp:GridView ID="GridView1" runat="server" CellPadding="4"
ForeColor="#333333"
GridLines="None" AutoGenerateColumns="False" DataSourceID="SqlDataSource1" Width="200px">
<AlternatingRowStyle CssClass="alt" />
<Columns>
<asp:BoundField DataField="Status" HeaderText="Status"
SortExpression="Status" />
<asp:BoundField DataField="Team" HeaderText="Team" SortExpression="Team" />
<asp:BoundField DataField="Time" HeaderText="Time" ReadOnly="True"
SortExpression="Time" />
<asp:TemplateField HeaderText="Request ID">
<ItemTemplate>
<asp:HyperLink ID="HyperLink1" runat="server" Target="_blank" NavigateUrl='<% # "link"+ Eval("Request") + "&"%>'><%#Eval("Request")%></asp:HyperLink>
</ItemTemplate>
</asp:TemplateField>
</Columns>
<HeaderStyle CssClass="header" />
<RowStyle CssClass="rst"></RowStyle>
</asp:GridView>
</h2>
</div>
<div id="incVolumeCon">
<h1>text</h1>
<h2>
flashfile
</h2>
</div>
<div id="reqSLACon">
<h1> text</h1>
<h2>
<asp:GridView ID="GridView2" runat="server" AutoGenerateColumns="False"
DataSourceID="blahblah" CellPadding="4" ForeColor="#333333"
GridLines="None" CssClass="mGrid" AlternatingRowStyle-CssClass="alt" RowStyle-CssClass="rst" Width = "400">
<Columns>
<asp:BoundField DataField="text" HeaderText="text" ReadOnly="True"
SortExpression="text" />
<asp:BoundField DataField="Dueby Time" HeaderText="text" ReadOnly="True"
SortExpression="text" />
<asp:BoundField DataField="text" HeaderText="text"
ReadOnly="True" SortExpression="text" />
<asp:BoundField DataField="text" HeaderText="text"
ReadOnly="True" SortExpression="text" />
<asp:BoundField DataField="Expr1" HeaderText="text" ReadOnly="True"
SortExpression="Expr1" />
<asp:TemplateField HeaderText="Request ID" >
<ItemTemplate>
<asp:HyperLink ID="HyperLink1" runat="server" Target="_blank" NavigateUrl='<%# "link"+ Eval("Request ID") + "&"%>'><%#Eval("Request ID")%></asp:HyperLink>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
test
</h2>
</div>
有什么想法吗?是什么导致我在IE 9中通过dev服务器从vs 2010查看它以及在生产服务器上的IE 9中查看它时之间的差异?
答案 0 :(得分:28)
您的网页使用“IE 9标准”以外的文档模式运行。
点击F12调出开发者工具,看看它实际上是什么。
请点击此处查看为何发生这种情况的说明:http://hsivonen.iki.fi/doctype/#ie8modes
否则,您可以将其添加到<head>
:
<meta http-equiv="X-UA-Compatible" content="IE=Edge" />
这将迫使IE使用其最新的渲染引擎。
这可以通过HTTP响应标头中的设置在IIS服务器中完成。 在Name字段中输入“X-UA-Compatible”并在Value字段中输入“IE = Edge” 在EDIT自定义HTTP响应标题中,如下图所示。
答案 1 :(得分:1)
我在几个网站上遇到过同样的问题。它在除IE9之外的所有浏览器(我测试过)中都能正确呈现。我通过在HEADER中插入<meta content="IE=8" http-equiv="X-UA-Compatible" />
解决了这个问题。
但在我看来情况下,它无法在本地或远程工作,所以如果你在本地渲染它可能是别的东西,但值得一试。
希望有所帮助....
答案 2 :(得分:0)
您是否手动转到服务器上的CSS文件的URL并查看它显示的内容?我预计它将是500内部服务器错误或类似的响应而不是实际的CSS代码。
答案 3 :(得分:0)
我们在对齐和边框上遇到了问题,在部署之后它发生了变化,
将此标记放在DOCTYPE之后的母版页中后,所有内容看起来都与本地内容相同。
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE8" />