IE兼容css3圆角的实现代码
程序员文章站
2023-10-21 22:28:13
以前做网页圆角一般是用圆角图片,但未免过于复杂,现在css3的border-radius属性可以很方便的实现圆角功能,对网站前台人员无疑是一件喜事,但悲剧的是IE6/7/8并不支持... 11-07-21...
让我们弃新技术不用,是不可能的,因此找到了一种解决的办法--- ie利用vml矢量可标记语言作为画笔绘出圆角:
下载一个压缩包ie-css3.htc,里面有一个微软的脚本文件(11kb)和一个用来测试服务器是否有正确的content-type的html文件,.htc 文件是ie内核支持web行为后用来描述此类行为的脚本文件。它们定义了一套方法和属性,程序员几乎可以把这些方法和属性应用到html页面上的任何元素上去。web 行为是非常伟大的因为它们允许程序员把自定义的功能“连接”到现有的元素和控件,而不是必须让用户下载二进制文件(例如activex 控件)来完成这个功能。
使用演示:
.main{
border: 2px solid #c0c0c0;
-moz-border-radius: 10px;
-webkit-border-radius: 10px;
border-radius: 10px;
position:relative;
z-index:100;
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: 400px; height:400px;”属性。
5、radius属性的10px是圆角半径,还可以给两个值如“border-radius: 10px 5px;”,这样则左上角与右下角半径为10px,右上角与左下角半径为5px。也可以赋4个值,为“上 右 下 左”。
下载一个压缩包ie-css3.htc,里面有一个微软的脚本文件(11kb)和一个用来测试服务器是否有正确的content-type的html文件,.htc 文件是ie内核支持web行为后用来描述此类行为的脚本文件。它们定义了一套方法和属性,程序员几乎可以把这些方法和属性应用到html页面上的任何元素上去。web 行为是非常伟大的因为它们允许程序员把自定义的功能“连接”到现有的元素和控件,而不是必须让用户下载二进制文件(例如activex 控件)来完成这个功能。
使用演示:
复制代码
代码如下:.main{
border: 2px solid #c0c0c0;
-moz-border-radius: 10px;
-webkit-border-radius: 10px;
border-radius: 10px;
position:relative;
z-index:100;
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: 400px; height:400px;”属性。
5、radius属性的10px是圆角半径,还可以给两个值如“border-radius: 10px 5px;”,这样则左上角与右下角半径为10px,右上角与左下角半径为5px。也可以赋4个值,为“上 右 下 左”。
上一篇: 拯救“早起困难症”的大招,你不服气算我