ie
使用固定的渲染模式:
代码如下:
<metahttp-equiv="x-ua-compatible"content="ie=8"><!--以ie8模式渲染-->
<metahttp-equiv="x-ua-compatible"content="ie=7"><!--以ie7模式渲染-->
还
有一种情况,在ie8下只有不使用兼容模式页面才能显示正常,但是如果设定为ie8的模式,在ie9中却会导致css3失效。看来,需要针对
ie8、ie9
分别
禁用兼容模式。怎么办呢?可以在后台判断浏览器版本,如果是ie8就输出content="ie=8",如果是ie9就输出
content="ie=9"。其实还可以单纯通过html来实现的,html代码如下:
<metahttp-equiv="x-ua-compatible"content="ie=9
ie=8
ie=7
ie=edge">
1、下载一个压缩包,里面有一个微软的脚本文件(11KB)和一个用来测试服务器是否有正确的Content-Type的HTML文件:iecss3.rar;.htc文件是IE内核支持Web行为后用来描述此类行为的脚本文件。它们定义了一套方法和属性,程序员几乎可以把这些方法和属性应用到HTML页面上的任何元素上去。Web 行为是非常伟大的因为它们允许程序员把自定义的功能“连接”到现有的元素和控件,而不是必须让用户下载二进制文件(例如ActiveX 控件)来完成这个功能。解压后,打开test.html,如果显示效果是圆角,则可以继续。
使用演示:
.main{
border: 2px solid #C0C0C0
-moz-border-radius: 10px
-webkit-border-radius: 10px
border-radius: 10px
position:relative
z-index:2
behavior: url(此处为ie-css3.htc文件的绝对路径)
}
Webkit内核的浏览器支持“-webkit-border-radius: 10px”属性(10px是圆角半径),可以直接解析出圆角;Firefox浏览器支持“-moz-border-radius: 10px”属性,也是可以直接解析出圆角;IE系浏览器则需要加上“border-radius: 15px”的属性。
注意事项:
1、behavior的url里一定要填写ie-css3.htc的绝对路径,因为 IE浏览器找该文件是相对当前html文件路径来找的,所以对于Wordpress等动态程序生成的页面一定要填写绝对路径。
2、一定要有定位属性:position:relative
3、因为在IE浏览器下这些CSS3效果的实现是要借助于VML,由VML绘制圆角或是投影效果,所以还需要一个z-index属性。z-index属性最好设置得比较大,如2。
4、如果在IE浏览器下某些模块无法用此渲染,可以试着绝对定位相应的层,即加上“ width: 400pxheight:400px”属性。
5、radius属性的10px是圆角半径,还可以给两个值如“border-radius: 10px 5px”,这样则左上角与右下角半径为10px,右上角与左下角半径为5px。也可以赋4个值,为“上 右 下 左”。
IE 6,7,8支持CSS3的部分属性。介绍htc,它可以让IE浏览器支持CSS3的border-radius、box-shadow、border-image、CSS3 Backgrounds (-pie-background)、Gradients、RGBA属性。。提示:PIE.htc URL路径是相对于当前HTML文件,不是CSS文件.
比如 当前文件在“/”下 ,CSS文件在“/CSS”下,PIE.htc在“/CSS”下,behavior: url(/css/PIE.htc) 而不是behavior: url(PIE.htc);
一、border-radius 圆角
代码如下:
.radius{
border: 1px solid #696
padding: 60px 0
text-align: centerwidth: 200px
-webkit-border-radius: 8px
-moz-border-radius: 8px
border-radius: 8px
background: #EEFF99
behavior: url(/PIE.htc)/* 可以让IE 6,7,8模拟部分的CSS3属性 */
}
说明:不支持单边的圆角属性,比如: border-top-left-radius,但是你可以这样来写:
border-radius 圆角
代码如下:
border-radius: 5px 10px 15px 20px/*top-left, top-right, bottom-right, bottom-left*/
二、box-shadow 盒子阴影
代码如下:
border: 1px solid #696
padding: 60px 0
text-align: centerwidth: 200px
-webkit-box-shadow: #666 0px 2px 3px
-moz-box-shadow: #666 0px 2px 3px
box-shadow: #666 0px 2px 3px
background: #EEFF99
behavior: url(/PIE.htc)/* 可以让IE 6,7,8模拟部分的CSS3属性 */
说明:不支持text-shadow(文本阴影)
box-shadow 盒子阴影
三、border-image 图片边框
代码如下:
color: white
border: 8px solid #013D7A
-webkit-border-radius: 8px
-moz-border-radius: 8px
-webkit-border-image: url(img/border.png) 8 8 8 8 stretch
-moz-border-image: url(img/border.png) 8 8 8 8 stretch
border-image: url(img/border.png) 8 8 8 8 fill stretch
behavior: url(PIE.htc)
用到的图片:
border-image 图片边框
四、CSS3 Backgrounds 背景渐变
代码如下:
.gradient{
background: #CCC/*fallback for non-CSS3 browsers*/
background: -webkit-gradient(linear, 0 0, 0 100%, from(#CCC) to(#EEE))/*old webkit*/
background: -webkit-linear-gradient(#CCC, #EEE)/*new webkit*/
background: -moz-linear-gradient(#CCC, #EEE)/*gecko*/
background: -ms-linear-gradient(#CCC, #EEE)/*IE10*/
background: -o-linear-gradient(#CCC, #EEE)/*opera 11.10+*/
background: linear-gradient(#CCC, #EEE)/*future CSS3 browsers*/
-pie-background: linear-gradient(#CCC, #EEE)/*PIE*/
behavior: url(PIE.htc)
}
说明:只支持linear-gradient(线性渐变)
linear-gradient 线性渐变
高级运用:
代码如下:
background-size: 50px
background-color: #0ae
background-image: -webkit-linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent)
background-image: -moz-linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent)
background-image: -ms-linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent)
background-image: -o-linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent)
background-image: linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent)
-pie-background: linear-gradient(rgba(255, 255, 255, .2) 50%, transparent 50%, transparent) 0 0 / 50px #0ae
behavior: url(/PIE.htc)
更多demo:
五、RGBA 颜色值
代码如下:
.rgba{
padding: 60px 0
background: #000
background: rgba(0,0,0,.2)
-pie-background: rgba(0,0,0,.2)
}
说明:不支持box-shadow
RGBA 颜色值
六、IE6 png 透明
代码如下:
.png img{
-pie-png-fix: true
behavior: url(/PIE.htc)
}
.png{
background-image:url(img.png)
-pie-background:url(img.png)
behavior: url(/PIE.htc)
}
说明:图片直接用-pie-png-fix: true,背景图片使用-pie-background来修复IE6下png透明的问题