IE9以下浏览器对CSS3的常用兼容处理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了IE9以下浏览器对CSS3的常用兼容处理相关的知识,希望对你有一定的参考价值。

参考技术A html5shiv:解决ie9以下浏览器对html5新增标签的不识别,并导致CSS不起作用的问题。

respond.min:让不支持css3 Media Query的浏览器包括IE6-IE8等其他浏览器支持查询。

官方网站: http://css3pie.com/
演示地址: http://css3pie.com/demos/gradient-patterns/

1.兼容border-radius;
2.阴影效果;
3.部分 CSS3 的效果,如 多张背景图,border-image,背景颜色渐变效果;
4.png 图片透明效果;

JS常用事件兼容性处理方法

event.js文件

//跨浏览器事件处理程序【根据能力检测调用】


var EventObject = {

//添加事件
AddEvent:function(obj , type , eventFn){
if(obj.addEventListener){//常用
obj.addEventListener(type , eventFn , false);
}
else if(obj.attachEvent){//IE8及以下
obj.attachEvent(‘on‘+type , eventFn);
}
else{//DOM零级事件处理
obj[‘on‘+type] = eventFn; //obj.onclick === obj[‘onclick‘]
}
},

//删除事件
DelEvent:function(obj , type , eventFn){
if(obj.removeEventListener){
obj.removeEventListener(type , eventFn , false);
}
else if(obj.detachEvent){
obj.detachEvent(‘on‘+type , eventFn);
}
else{
obj[‘on‘+type] = null;
}
},

//获取事件对象
GegEvent:function(event){
return event ? event : window.event;
},

//获取事件类型
GetType:function(event){
return event.type;
},

//获取事件目标
GetTarget:function(event){
return event.target || event.srcElement;
},

//阻止事件默认行为
PreventDefault:function(event){
if(event.preventDefault){
event.preventDefault();
}
else{
event.returnValue = false; //IE8及以下的版本
}
},

//阻止事件冒泡
StopPropagation:function(event){
if(event.stopPropagation){
event.stopPropagation();
}
else{
event.cancelBubble = true; //IE8及以下的版本
}
}

};


index.html页面

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>事件对象封装调用</title>
<style type="text/css">
div{border: 1px solid red; padding: 20px;}
</style>
</head>
<body>
<div id="divBox">
<input type="button" name="btn1" id="btn1" value="通用跨浏览器点击事件" />
<input type="button" name="btn2" id="btn2" value="事件类型type" />
<input type="button" name="btn3" id="btn3" value="事件目标target" />
<input type="button" name="btn4" id="btn4" value="元素节点名称target.nodeName" />
<input type="button" name="btn5" id="btn5" value="阻止事件冒泡stopPropagation()" />
<a href="http://www.baidu.com" id="Go">打开百度 阻止默认行为preventDefault()</a>
</div>
</body>
<script src="event.js" type="text/JavaScript" charset="utf-8"></script>
<script type="text/javascript">
var Box = document.getElementById("divBox");
EventObject.AddEvent(Box , "click" , mupiao);
function mupiao(){
alert("我是装按扭的DIV")
}

var btn1 = document.getElementById("btn1");

EventObject.AddEvent(btn1 , "click" , mupiao1); //添加事件方法

function mupiao1(){
alert("我调用了封装的事件对象方法!");
}

//EventObject.DelEvent(btn1 , "click" , mupiao); //删除事件方法

var btn2 = document.getElementById("btn2");
EventObject.AddEvent(btn2 , "click" , mupiao2);
function mupiao2(event){
alert(event.type); //事件类型(它是event的属性)
}

var btn3 = document.getElementById("btn3");
EventObject.AddEvent(btn3 , "click" , mupiao3);
function mupiao3(event){
var event = event || window.event;
var ele = event.target || event.srcElement;
alert(ele);//事件目标(它是event的属性)
ele.style.background = "red"
}

var btn4 = document.getElementById("btn4");
EventObject.AddEvent(btn4 , "click" , mupiao4);
function mupiao4(event){
var e = EventObject.GegEvent(event);
var ele = EventObject.GetTarget(e);
alert(ele.nodeName);//元素节点名称(它是event的属性)
}

var btn5 = document.getElementById("btn5");
EventObject.AddEvent(btn5 , "click" , mupiao5);
function mupiao5(event){
event.stopPropagation(); //阻止事件冒泡
alert("阻止事件冒泡stopPropagation()");//元素节点名称(它是event的方法)
}

var go = document.getElementById("go");
EventObject.AddEvent(go , "click" , goFn);
function goFn(event){
EventObject.PreventDefault(event);
EventObject.StopPropagation(event);
alert("阻止默认行为preventDefault()");//元素节点名称(它是event的方法)
}
</script>
</html>


以上是关于IE9以下浏览器对CSS3的常用兼容处理的主要内容,如果未能解决你的问题,请参考以下文章

ie9不支持vue的v-for循环怎么处理

bootstrap4支持IE9+浏览器吗

IE9以下兼容 @font-face的处理方案

浏览器兼容性问题整理

主流浏览器CSS 3和HTML 5兼容清单

CSS3 和 HTML5 兼容的浏览器