*新闻详情页*/>
1. Div垂直居中难题
div设定 margin-left, margin-right 为 auto 时早已垂直居中,
IE 不好,IE必须设置body垂直居中,
最先在父级元素界定text-algin: center;
这个的意思便是在父级元素内的內容垂直居中。
2.连接(a标识)的边框与情况
a 连接加边框和情况色,需设定 display: block, 另外设定 float: left 确保不换行。
参考 menubar, 给 a 和 menubar 设定高宽比是以便防止底边显示信息移位,
若不设 height, 能够在 menubar 中插进1个空格。
3.超连接浏览之后hover款式就不出現的难题
被点一下浏览过的超连接款式不在具备hover和active了
处理方式是
更改CSS特性的排序次序: L-V-H-A
Code:
<style type="text/css">
<!--
a:link {}
a:visited {}
a:hover {}
a:active {}
-->
</style>
4. 游标手指cursor
cursor: pointer 能够另外在 IE FF 中显示信息游标手指状,
hand 仅 IE 能够
5.UL的padding与margin
ul标识在FF中默认设置是有padding值的,
而在IE中仅有margin默认设置有值,
因此先界定 ul{margin:0;padding:0;}就可以处理绝大多数难题
6. FORM标识
这个标识在IE中,可能全自动margin1些边距,而在FF中margin则是0,
因而,假如想显示信息1致,因此最好是在css中特定margin和 padding,
对于上面两个难题,我的css中1般最先都应用这样的款式
ul,form{margin:0;padding:0;}
给界定死了,因此后边就不容易为这个头疼了.
7. BOX实体模型解释不1致难题
在FF和IE 中的BOX实体模型解释不1致致使相差2px
处理方式:
div{margin:30px!important;margin:28px;}
留意这两个 margin的次序1定不可以写反, important这个特性IE不可以鉴别,
但其他访问器能够鉴别。
因此在IE下实际上解释成这样:
div {maring:30px;margin:28px}
反复界定的话依照最终1个来实行,因此不能以只写margin:xx px!important;
#box
{
width:600px; //for ie6.0\
- w\idth:500px; //for ff+ie6.0}
#box{
width:600px!important //for ff
width:600px; //for ff+ie6.0
width /**/:500px; //for ie6.0-}
8.特性挑选器(这个不可以算是适配,是掩藏css的1个bug)
p[id]{}div[id]{}
这个针对IE6.0和IE6.0下列的版本号都掩藏,
FF和OPera功效.特性挑选器和子挑选器還是有差别的,
子挑选器的范畴从方式来讲变小了,
特性挑选器的范畴较为大,
如p[id]中,全部p标识中有id的全是一样式的.
9.最狠的方式 - !important;
假如确实沒有方法处理1些细节难题,
能够用这个方式.FF针对”!important”会全自动优先选择分析,
但是IE则会忽视.
以下
.tabd1
{
background:url(/res/images/up/tab1.gif) no-repeat 0px 0px !important; /*Style for FF*/
background:url(/res/images/up/tab1.gif) no-repeat 1px 0px; /* Style for IE */}
值得留意的是,1定要将xxxx !important 这句置放在另外一句之上,上面早已提过
10.IE,FF的默认设置值难题
也许你1直在埋怨为何要专业为IE和FF写不一样的CSS,
为何IE这样令人头疼,随后1边写css,1边谩骂那个可恨的M$ IE.
实际上针对css的规范适用层面,IE并沒有大家想像的那末可恨,
重要在于IE和FF的默认设置值不1样罢了,把握了这个技能,
你会发现写出适配FF和IE的css其实不是那末艰难,也许针对简易的css,
你彻底能够无需”!important”这个物品了。
大家都了解,访问器在显示信息网页页面的情况下,都会依据网页页面的 css款式表来决策怎样显示信息,
可是大家在款式表格中不一定会将全部的元素都开展了实际的叙述,
自然也沒有必要那末做,因此针对那些沒有叙述的特性,
访问器将选用内嵌默认设置的方法来开展显示信息,例如文本,
假如你沒有在css中特定色调,那末访问器将选用黑色或系统软件色调来显示信息,div或别的元素的情况,
假如在 css中沒有被特定,访问器则将其设定为白色或全透明,这些别的待定义的款式均这般。
因此有许多物品出現FF和IE显示信息不1样的压根缘故在于它们的默认设置显示信息不1样,而这个默认设置款式该怎样显示信息我了解在w3中有木有对应的规范来开展要求,
因而针对这点也就别去怪罪IE了。
11.为何FF下文字没法撑开器皿的高宽比
规范访问器中固定不动高宽比值的器皿是不容易象IE6里那样被撑开的,
那我又想固定不动高宽比,又想能被撑开必须如何设定呢?
方法便是去掉height设定min-height:200px;
这里以便照料不了解min-height的IE6
能够这样界定: { height:auto!important; height:200px; min-height:200px; }
12.FireFox下怎样使持续长字段全自动换行
大家都知道IE中立即应用 word-wrap:break-word 便可以了,
FF中大家应用JS插进的方式来处理
<style type="text/css">
<!--
div
{
width:300px;
word-wrap:break-word;
border:1px solid red; }
-->
</style>
<div id="ff">这里是1行很长的文本aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa</div>
<scrīpt type="text/javascrīpt">
/* <![CDATA[ */
function toBreakWord(el, intLen)
{
var ōbj=document.getElementById(el);
var strContent=obj.innerHTML;
var strTemp="";
while(strContent.length>intLen)
{
strTemp+=strContent.substr(0,intLen)+" ";
strContent=strContent.substr(intLen,strContent.length);
}
strTemp+=" "+strContent;
obj.innerHTML=strTemp;
}
if(document.getElementById && !document.all)
toBreakWord("ff", 37);
/* ]]> */
</scrīpt>
13.为何IE6下器皿的宽度和FF解释不一样呢
<?xml version="1.0" encoding="gb2312"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<style type="text/css">
<!--div
{
cursor:pointer;
width:200px;
height:200px;
border:10px solid red
}
-->
</style>
<div ōnclick="alert(this.offsetWidth)">让FireFox与IE适配</div>
难题的区别在于器皿的总体宽度有木有将边框(border)的宽度算在其内,
这里IE6解释为200PX ,而FF则解释为220PX,那到底是如何致使的难题呢?
大伙儿把器皿顶部的xml去掉就会发现原先难题出在这,顶部的声明开启了IE的qurks mode,有关qurks mode、 standards mode的有关专业知识,
请参照:http: //www.microsoft.com/china/msdn/library/webservices/asp.net/ ASPNETusStan.mspx?mfr=true
IE6,IE7,FF IE7.0 出来了,对CSS的适用又有新难题。访问器多了,网页页面适配性更差了,疲于奔命的還是大家 ,
为处理IE7.0的适配难题,找来了下面这篇文章内容:
如今我绝大多数全是用!important来hack,针对ie6和firefox检测能够一切正常显示信息,
可是ie7对!important能够正确解释,会致使网页页面没按规定显示信息!
下面是3个访问器的适配性搜集.
第1种,是CSS HACK的方式
height:20px; /*For Firefox*/
*height:25px; /*For IE7 & IE6*/
_height:20px; /*For IE6*/
留意次序。
这样也属于CSS HACK,但是沒有上面这样简约。
#example { color: #333; } /* Moz */
* html #example { color: #666; } /* IE6 */
*+html #example { color: #999; } /* IE7 */
第2种,标准注解
<!--别的访问器 –>
<link rel="stylesheet" type="text/css" href="css.css" />
<!--[if IE 7]> <!-- 合适于IE7 –>
<link rel="stylesheet" type="text/css" href="ie7.css" />
<![endif]—>
<!--[if lte IE 6]>
<!-- 合适于IE6及1下 –>
<link rel="stylesheet" type="text/css" href="ie.css" />
<![endif]—>
第3种,css filter的方法,下列为經典从海外网站汉语翻译过来的。
新建1个css款式以下:
#item
{
width: 200px;
height: 200px;
background: red;
}
新建1个div,并应用前面界定的css的款式:
<div id="item">some text here</div>
在body主要表现这里添加lang特性,汉语为zh: <body lang="en">
如今对div元素再界定1个款式: *:lang(en) #item{ background:green !important;}
这样做是以便用!important遮盖原先的css款式,因为:lang挑选器ie7.0其实不适用,因此对这句话不容易有任何功效,
因而也做到了ie6.0下一样的实际效果,可是很悲剧地的是,safari一样不适用此特性,因此必须添加下列css款式:
#item:empty {background: green !important }
:empty挑选器为css3的标准,虽然safari其实不适用此标准,
可是還是会挑选此元素,无论是不是此元素存在,如今翠绿色会如今在除ie各版本号之外的访问器上。
对IE6和FF的适配能够考虑到之前的!important 本人较为喜爱用第1种,简约,适配性较为好。
Copyright © 2002-2020 ps网页版在线制作_静态网页制作方法_微云网页版_怎么制作一个网页_django网页模板 版权所有 (网站地图) 粤ICP备10235580号