1、各大厂商出于自身利益考虑而设置的种种技术壁垒,都让CSS应用起来比想象得要麻烦
2、由于各大主流浏览器由不同的厂家开发,所用的核心架构和代码也很难重和,这就为各种莫名其妙的Bug(代码错误)提供了温床
Trident 代表作:IE
Gecko 代表作:Mozilla
WebKit 代表作:Safari 和Google旧版
Blink 代表作:Google 和 Opera
Presto ( Opera前内核 已经废弃 )
针对上述常见的浏览器由于使用的内核和规范都不完全同一,因此会出现一些浏览的兼容问题。
在IE6浏览器不识别改属性,IE6兼容元素最小高度自适应方法:
方法1:min-height:200px;_height:200px;
方法2:min-height:200px;height:auto !important;height:200px;(不能换顺序)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
div{
width: 200px;
min-height: 200px;
background: red;
/* 解决方法使用过滤器 */
/* _height:200px; 第一种解决方法 */
/* height: auto !important;
height: 200px; 第二种解决方法 */
}
</style>
</head>
<body>
<div></div>
</body>
</html>
1.当图片添加<a href="#"></a>在IE上会出现边框,
解决方案:
给图片添加border:0;或者border:none;
2.图片缝隙问题 在网页中插入图片的时候,图片会默认向下撑大3px
解决方案:
将图片元素转为块元素display:block;或者给img标签添加声明vertical-algin:top;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
div{
border: 5px solid red;
overflow: hidden;
}
img {
/* 第一种解决方法 */
/* display: block; */
/* 第二种解决方法 */
vertical-align: top;
}
</style>
</head>
<body>
<div><img src="./img/u=1468287185,598790534&fm=111&gp=0.jpg" alt=""></div>
</body>
</html>
表单元素距离顶部间距不一致
解决方案:
给表单元素声明:float:left;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body{
margin: 0;padding: 0;
}
input{
float: left;
}
</style>
</head>
<body>
<input type="text">
<button>按钮</button>
</body>
</html>
cursor属性的hand属性值只有在IE9以下浏览器识别,其他浏览器不识别该声明。
解决方案:
cursor:pointer;
下面图一是谷歌浏览器显示hand的鼠标
图二是IE8的显示,是可以显示出小手的形状
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
div{
width: 200px;
height: 200px;
background: red;
/* cursor: hand; */
/* 解决方案 */
cursor: pointer;
}
</style>
</head>
<body>
<div></div>
</body>
</html>
图一
图二
给子元素设置任何浮动,设置了margin-top属性后,或错误的吧margin-top的属性值添加个父元素
解决方案:
1.给子元素或者父元素设置浮动
2.给父元素添加上边框
3.给父元素添加overflow:hidden;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body{
margin: 0;padding: 0;
}
.parent{
width: 200px;
height: 200px;
background-color: red;
/* 第一种方法 */
/* overflow: hidden; */
/* 第二种方法 */
/* float: left; */
/* 第三种方案 */
/* border: 1px solid transparent; */
}
.son {
width: 100px;
height: 100px;
background: yellow;
margin-top: 50px;
/* 第四种解决方案 */
/* float: left; */
}
</style>
</head>
<body>
<div class="parent">
<div class="son"></div>
</div>
</body>
</html>
一般浏览器使用透明属性只需要opacity:value(value的取值范围0-100整数)
但是在IE浏览器中这个属性无法被单独识别
解决方法:
filter:alpha(opacity=value)取值范围0-100整数
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body{
margin: 0;padding: 0;
}
div{
width: 200px;
height: 200px;
background: red;
opacity: .5;
/* 解决方法 IE */
/* filter: alpha(opacity=50); */
}
</style>
</head>
<body>
<div></div>
</body>
</html>
谷歌浏览器最小字号只支持到12px,12px以下的字号不支持
解决方案:
1.直接切图
2.在html或者body里添加一句浏览器专有属性-weblit-text-size-adjust:none;注意在新本的谷歌浏览器中已经不生效了
3.CSS的一个缩放属性:transform:scale();同时需要配合transform-orgin属性才能达到完美的显示效果
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body{
margin: 0;padding: 0;
/* 第一种解决方案 最新谷歌浏览器没有用 */
/* -webkit-text-size-adjust: none; */
}
p{
font-size: 6px;
background: skyblue;
/* 第二种解决方案 */
transform: scale(.5);
transform-origin: left center;
/* 第三种切图方式就是插入图片,自行操作 */
}
</style>
</head>
<body>
<p>你好</p>
</body>
</html>
这是在谷歌12px的字体大小
这是在谷歌浏览器下设置6px的文字,是没有发生变化的
这是IE浏览器中6px显示的效果,文字的确变小
通过以上方案解决后显示的效果
图片png24格式在IE6上不透明
解决方法:
把png24格式换成png8或者gif格式
在IE6及更低版本浏览器在解析浮动元素是,会错误把浮向边边界(margin)加倍显示
解决方案:
给浮动元素添加声明:display:inline
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body,ul,li {
margin: 0;
padding: 0;
}
li {
/* 解决方案 */
display: inline;
margin-left: 40px;
list-style: none;
border: 4px solid red;
float: left;
}
</style>
</head>
<body>
<ul>
<li>你好美女</li>
<li>你好美女</li>
<li>你好美女</li>
<li>你好美女</li>
</ul>
</body>
</html>
在IE6及更低版本的浏览器里,如果想去掉input的默认边框,不能设置border:none;
解决方案:
input{border:0;}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
input{
border: 0;
}
</style>
</head>
<body>
<input type="text" value="你好">
</body>
</html>
这是使用border:none;无法取出input的边框
这里使用border:0;可以解决input边框问题
如果设置了input的高度,在其他浏览器上显示的value的内容垂直居中的,但是在IE6上是顶部的
解决方案:
给input添加一个行高等于他的高度
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
input{
height: 50px;
line-height: 50px;
}
</style>
</head>
<body>
<input type="text" value="你好美女">
</body>
</html>
没有使用行高等于高度出现的兼容
使用行高等于高度完美解决文字偏上问题
在IE及以下版本中在解析百分比时,会四舍五入方式计算从而导致50%加50%大于100%的情况
解决方案:
给右边浮动元素添加声明clear:both;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body {
margin: 0;padding: 0;
}
.b1{
width: 50%;
height: 200px;
float: left;
background: red;
}
.b2 {
/* 解决方案 */
clear: right;
width: 50%;
height: 200px;
float: left;
background: yellow;
}
</style>
</head>
<body>
<div class="b1"></div>
<div class="b2"></div>
</body>
</html>
解析百分比大于100%的情况
解决后的显示效果
IE7及以下浏览器li有时候会莫名向下撑大3-4px
解决方案:
给li添加一个+margin-top:-3px或者-4px;
1) 下划线属性过滤器 选择符{_属性:属性值;}由于符合标准的浏览器不能识别带有下划线的属性而忽略了这个声明,但是在IE6更低版本浏览器中会继续解析这个规则
2)!important关键字过滤器 选择符{属性:属性值 !important;}他表示所附加的声明具有最高优先级的意思。但由于IE6及更低版本不能识别它,我们可以利用IE6的这个Bug作为过滤器来兼容IE6和其他标准浏览器。
3) \9 选择符{属性:属性值\9;} IE浏览器组识别
4) \0 选择符{属性:属性值\0;} 只有IE8以上浏览器起作用
5) + 或着 * 选择符{属性:属性值;} IE7及以下
6) :root选择器 :root 选择符{属性:属性值;} 除了IE8及更早的浏览器识别
? 逆战班_许富荧
原文:https://www.cnblogs.com/xfy196/p/12354084.html