在网頁制作时,圆角的样式在很多时候都要到,大多数都是用图片来搞,其实图片不图片无所谓的,但也有的朋友比较喜欢用CSS来写,CSS写的话在火狐、谷歌等浏览器都是没有问题的 。但是在IE下就会出现问题,圆角就没有了 。这时候就要用到一个文件,当时那个文件是哪里下的已经记不清了,但用着还是挺不错的 。由于不知道怎么上传文件,就只能把源码弄出来了 。
test.html
复制代码代码如下:
html
headtitletest/title
style type="text/css"
.test {
width:100px;
height:100px;
background-color: blue;
margin-bottom:10px;
border-radius: 10px;
behavior: url(ie-css3.htc);
}
/style
/head
body
div class="test"
test
/div
/body
/html
ie-css3.htc
复制代码代码如下:
--Do not remove this if you are using--
Original Author: Remiz Rahnas
Original Author URL: http://www.htmlremix.com
Published date: 2008/09/24
Changes by Nick Fetchak:
- IE8 standards mode compatibility
- VML elements now positioned behind original box rather than inside of it - should be less prone to breakage
- Added partial support for ’box-shadow’ style
- Checks for VML support before doing anything
- Updates VML element size and position via timer and also via window resize event
- lots of other small things
Published date : 2010/03/14
http://fetchak.com/ie-css3
Thanks to TheBrightLines.com (http://www.thebrightlines.com/2009/12/03/using-ies-filter-in-a-cross-browser-way) for enlightening me about the DropShadow filter
public:attach event="ondocumentready" onevent="ondocumentready(’v08vnSVo78t4JfjH’)" /
script type="text/javascript"
timer_length = 200; // Milliseconds
border_opacity = false; // Use opacity on borders of rounded-corner elements? Note: This causes antialiasing issues
// supportsVml() borrowed from http://stackoverflow.com/questions/654112/how-do-you-detect-support-for-vml-or-svg-in-a-browser
function supportsVml() {
if (typeof supportsVml.supported == "undefined") {
var a = document.body.appendChild(document.createElement(’div’));
a.innerHTML = ’v:shape id="vml_flag1" adj="1" /’;
var b = a.firstChild;
b.style.behavior = "url(#default#VML)";
supportsVml.supported = b ? typeof b.adj == "object": true;
a.parentNode.removeChild(a);
}
return supportsVml.supported
}
// findPos() borrowed from http://www.quirksmode.org/js/findpos.html
function findPos(obj) {
var curleft = curtop = 0;
if (obj.offsetParent) {
do {
curleft= obj.offsetLeft;
curtop= obj.offsetTop;
} while (obj = obj.offsetParent);
}
return({
’x’: curleft,
’y’: curtop
});
}
function createBoxShadow(element, vml_parent) {
var style = element.currentStyle[’iecss3-box-shadow’] || element.currentStyle[’-moz-box-shadow’] || element.currentStyle[’-webkit-box-shadow’] || element.currentStyle[’box-shadow’] || ’’;
var match = style.match(/^(d )px (d )px (d )px/);
if (!match) { return(false); }
var shadow = document.createElement(’v:roundrect’);
shadow.userAttrs = {
’x’: parseInt(RegExp.$1 || 0),
’y’: parseInt(RegExp.$2 || 0),
’radius’: parseInt(RegExp.$3 || 0) / 2
};
shadow.position_offset = {
’y’: (0 - vml_parent.pos_ieCSS3.y - shadow.userAttrs.radiusshadow.userAttrs.y),
’x’: (0 - vml_parent.pos_ieCSS3.x - shadow.userAttrs.radiusshadow.userAttrs.x)
};
shadow.size_offset = {
’width’: 0,
’height’: 0
};
shadow.arcsize = element.arcSize’px’;
shadow.style.display = ’block’;
shadow.style.position = ’absolute’;
shadow.style.top = (element.pos_ieCSS3.yshadow.position_offset.y)’px’;
shadow.style.left = (element.pos_ieCSS3.xshadow.position_offset.x)’px’;
shadow.style.width = element.offsetWidth’px’;
推荐阅读
- Mac注意事项模板1
- 腾讯地图APP删除已经下载离线地图的方法步骤
- Mac注意事项模板2
- Mac注意事项模板3
- 修改隐藏L7下方的横条
- ie-css3.htc 让IE6, 7, and 8也支持box-shadow
- IE6、IE7、IE8浏览器下的CSS、JS兼容性对比
- 汽车一键启动要按几下
- 针对IE8正式版的CSS hack
- 部分 IE Firefox在css中的差别