跨浏览器开发经验总结(二) CSS
网站建设 2023-01-28 20:49www.1681989.com免费网站
CSS类级别的hack仅IE7识别 +html {…}
IE6及IE6以下识别 html {…}
opera、safari、chrome识别
@media all and (m-width: 0px){…} //Firefox3.0.6不识别,但Firefox3.6也识别该规则,如果Firefox版本有严格要求,请使用下一条规则
@media screen and (-webkit-m-device-pixel-ratio:0){…} //IE、Firefox不识别该规则
仅opera识别
@media screen and (-webkit-m-device-pixel-ratio:10000),not all and (-webkit-m-device-pixel-ratio:0{…}
CSS属性级别的hack仅IE识别 marg-left:10px\9;
仅IE8识别 marg-left:10px\0;
IE6/IE7识别 marg-left:10px;
仅IE6识别 : _marg-left:10px;
CSS Hack综合示例
/add 'marg-: -10px;' for IE7/Firefox/Opera/Safari/Chrome , 'marg-: 5px;' for IE8 /
.news_list01 h2 span{float: right; marg-: 5px; marg-: -10px; display: le}
@media all and (m-width: 0px){
.news_list01 h2 span{float: right; height: 19px; marg: 0 0 0 0; paddg-: 16px; paddg-bottom: 0; display: le}
}
HTML代码片断级别的hack(仅IE识别)① <!--[if !IE]> 除IE外都可识别的代码片断<![endif]-->
② <!--[if IE]> 所有的IE可识别的代码片断 <![endif]-->
③ <!--[if IE 7]> 仅IE7可识别的代码片断 <![endif]-->
④ <!--[if lt IE 7]> IE7以及IE7以下版本可识别的代码片断<![endif]-->
⑤ <!--[if gte IE 7]> IE7以及IE7以上版本可识别的代码片断 <![endif]-->
用脚本设置CSS属性
设置元素的style样式
Var spanElement = document.getElementById(“mySpan”);
//狼蚁网站SEO优化写法保证出IE外,所有浏览器可用
spanElement.setAttribute(“style”,”font-weight:bold;color:red;”);
//狼蚁网站SEO优化的写法保证IE可用
spanElement.style.cssText=”font-weight:bold;color:red;”;
设置元素的class属性
Var element = document.getElementById(“myElement”);
//狼蚁网站SEO优化的写法保证除IE外,所有浏览器可用
Element.setAttribute(“class”,”styleClass”);
//狼蚁网站SEO优化写法保证IE可用
Element.setAttribute(“className”,”styleClass”);
具体CSS效果的实现
按钮悬停时鼠标呈现手的形状
cursor:hand和cursor:poter效果是一样的,当鼠标移动至该元素时呈现手的形状。应该尽量使用cursor:poter而非cursor:hand,因为cursor:hand只有IE识别,而cursor:poter才是CSS2.0的标准属性,IE之外的浏览器也支持。
窗口滚动条显示问题
在使用弹出窗口或者框窗口架的时候,有时会有多余的滚动条出现,这时需要从多个方面进行确认
弹出窗口时wdow.open方法参数中设置的窗样式是否定义了scroll=yes
框架标签的属性中是否设置了scrollg=“yes”
窗口或框架内页面的CSS中,是否对html或body的overflow进行了样式定义,如果没有请参考如下代码。
html {
marg: 0;
paddg: 0;
overflow-x:hidden;
overflow-y:hidden;
}
le-height 属性
le-height行高指的是文本行的基线间的距离,即字体最底端与字体内部顶端之间的距离。如下图所示
文本之间的空白距离(行距)不仅仅是行高决定的,也受字号的影响。有时侯同一行内的不同元素底边没有对齐,有可能就是行高不统一造成的,这时关调整高度和对齐方式是不够的,还需要调整le-height属性。
display:le-block
display 属性有三个值block,le,le-block。其中display:block就是将元素显示为块级元素;display:le就是将元素显示为行内元素;display:le-block将对象呈递为内联对象,对象的内容作为块对象呈递。旁边的内联对象会被呈递在同一行内。
l block元素的特点是总是在新行上开始;高度,行高以及顶和底边距都可控制;宽度缺省是它的容器的100%,除非设定一个宽度。<div>, <p>, <h1>, <form>, <ul> 和 <li>是块元素的例子, display属性默认值为block。
l le元素的特点是 和其他元素都在一行上;高,行高及顶和底边距不可改变;宽度就是它的文字或图片的宽度,不可改变。<span>, <a>, <label>, <put>, <img>, <strong> 和<em>是le元素的例子, display属性默认值为le。
l le-block的元素特点呈现为内联对象,四周元素保持在同一行,但可以设置宽度和高度地块元素的属性,目前IE8、Firefox3、Opera、Safari都可以支持该属性了。
div中的文字自动换行问题
目前控制换行是使用以下CSS
div.content {
word-wrap:break-word;
overflow:hidden;
}
在 IE 、Firefox、Safari、Chrome下没有任何问题,在 Opera下,长串英文会被遮住超出的内容。如果想要让长串英文字符也自动换行,还需要设置word-break:break-all; (,此方式会导致普通的英文语句中的单词会被断开,ie下也是)。英文单词在排版规则上不应该被断开,长串英文字符其实就是一个比较长的单词,自然也不需要断开换行显示了,所以一般不需要额外设置word-break:break-all; 。
textarea中的文字自动换行问题
在textarea中设置输入内容的自动换行,也是在CSS中设置word-wrap:break-word;属性。需要额外注意的是textarea元素本身有一个warp属性,其取值含义如下
off不自动换行;
hard自动硬回车换行,换行标记一同被传送到服务器端(Opera、Chrome下不传);
soft自动软回车换行,换行标记不会传送到服务器端。
IE6及IE6以下识别 html {…}
opera、safari、chrome识别
@media all and (m-width: 0px){…} //Firefox3.0.6不识别,但Firefox3.6也识别该规则,如果Firefox版本有严格要求,请使用下一条规则
@media screen and (-webkit-m-device-pixel-ratio:0){…} //IE、Firefox不识别该规则
仅opera识别
@media screen and (-webkit-m-device-pixel-ratio:10000),not all and (-webkit-m-device-pixel-ratio:0{…}
CSS属性级别的hack仅IE识别 marg-left:10px\9;
仅IE8识别 marg-left:10px\0;
IE6/IE7识别 marg-left:10px;
仅IE6识别 : _marg-left:10px;
CSS Hack综合示例
/add 'marg-: -10px;' for IE7/Firefox/Opera/Safari/Chrome , 'marg-: 5px;' for IE8 /
.news_list01 h2 span{float: right; marg-: 5px; marg-: -10px; display: le}
@media all and (m-width: 0px){
.news_list01 h2 span{float: right; height: 19px; marg: 0 0 0 0; paddg-: 16px; paddg-bottom: 0; display: le}
}
HTML代码片断级别的hack(仅IE识别)① <!--[if !IE]> 除IE外都可识别的代码片断<![endif]-->
② <!--[if IE]> 所有的IE可识别的代码片断 <![endif]-->
③ <!--[if IE 7]> 仅IE7可识别的代码片断 <![endif]-->
④ <!--[if lt IE 7]> IE7以及IE7以下版本可识别的代码片断<![endif]-->
⑤ <!--[if gte IE 7]> IE7以及IE7以上版本可识别的代码片断 <![endif]-->
用脚本设置CSS属性
设置元素的style样式
Var spanElement = document.getElementById(“mySpan”);
//狼蚁网站SEO优化写法保证出IE外,所有浏览器可用
spanElement.setAttribute(“style”,”font-weight:bold;color:red;”);
//狼蚁网站SEO优化的写法保证IE可用
spanElement.style.cssText=”font-weight:bold;color:red;”;
设置元素的class属性
Var element = document.getElementById(“myElement”);
//狼蚁网站SEO优化的写法保证除IE外,所有浏览器可用
Element.setAttribute(“class”,”styleClass”);
//狼蚁网站SEO优化写法保证IE可用
Element.setAttribute(“className”,”styleClass”);
具体CSS效果的实现
按钮悬停时鼠标呈现手的形状
cursor:hand和cursor:poter效果是一样的,当鼠标移动至该元素时呈现手的形状。应该尽量使用cursor:poter而非cursor:hand,因为cursor:hand只有IE识别,而cursor:poter才是CSS2.0的标准属性,IE之外的浏览器也支持。
窗口滚动条显示问题
在使用弹出窗口或者框窗口架的时候,有时会有多余的滚动条出现,这时需要从多个方面进行确认
弹出窗口时wdow.open方法参数中设置的窗样式是否定义了scroll=yes
框架标签的属性中是否设置了scrollg=“yes”
窗口或框架内页面的CSS中,是否对html或body的overflow进行了样式定义,如果没有请参考如下代码。
复制代码
代码如下:html {
marg: 0;
paddg: 0;
overflow-x:hidden;
overflow-y:hidden;
}
le-height 属性
le-height行高指的是文本行的基线间的距离,即字体最底端与字体内部顶端之间的距离。如下图所示
文本之间的空白距离(行距)不仅仅是行高决定的,也受字号的影响。有时侯同一行内的不同元素底边没有对齐,有可能就是行高不统一造成的,这时关调整高度和对齐方式是不够的,还需要调整le-height属性。
display:le-block
display 属性有三个值block,le,le-block。其中display:block就是将元素显示为块级元素;display:le就是将元素显示为行内元素;display:le-block将对象呈递为内联对象,对象的内容作为块对象呈递。旁边的内联对象会被呈递在同一行内。
l block元素的特点是总是在新行上开始;高度,行高以及顶和底边距都可控制;宽度缺省是它的容器的100%,除非设定一个宽度。<div>, <p>, <h1>, <form>, <ul> 和 <li>是块元素的例子, display属性默认值为block。
l le元素的特点是 和其他元素都在一行上;高,行高及顶和底边距不可改变;宽度就是它的文字或图片的宽度,不可改变。<span>, <a>, <label>, <put>, <img>, <strong> 和<em>是le元素的例子, display属性默认值为le。
l le-block的元素特点呈现为内联对象,四周元素保持在同一行,但可以设置宽度和高度地块元素的属性,目前IE8、Firefox3、Opera、Safari都可以支持该属性了。
div中的文字自动换行问题
目前控制换行是使用以下CSS
复制代码
代码如下:div.content {
word-wrap:break-word;
overflow:hidden;
}
在 IE 、Firefox、Safari、Chrome下没有任何问题,在 Opera下,长串英文会被遮住超出的内容。如果想要让长串英文字符也自动换行,还需要设置word-break:break-all; (,此方式会导致普通的英文语句中的单词会被断开,ie下也是)。英文单词在排版规则上不应该被断开,长串英文字符其实就是一个比较长的单词,自然也不需要断开换行显示了,所以一般不需要额外设置word-break:break-all; 。
textarea中的文字自动换行问题
在textarea中设置输入内容的自动换行,也是在CSS中设置word-wrap:break-word;属性。需要额外注意的是textarea元素本身有一个warp属性,其取值含义如下
off不自动换行;
hard自动硬回车换行,换行标记一同被传送到服务器端(Opera、Chrome下不传);
soft自动软回车换行,换行标记不会传送到服务器端。
网站设计
- 静宁会SEO的网站建设公司:全面提升您的网络影
- 提升在线业务的关键:选择最佳的丽水网站建设
- 浙江网站优化发展潜力如何
- 井研专业的网站建设公司:打造您的在线品牌
- 灵山SEO网站建设公司:提升您的在线业务表现
- 蒙城网站建设优化公司:提升您网站表现的理想
- 阳谷企业网站优化:提升线上业务力的关键
- 樟树专业的网站建设公司:打造您在线业务的坚
- 通河百度SEO排名的策略与技巧
- 重庆百度快照排名如何进行精准的客户引流
- 重庆百度快照排名
- 常宁便宜的建站公司:助您轻松打造在线业务
- 巫溪百度网站优化:提升网站曝光率与流量的关
- 湖北整站优化怎么做才能放大客户需求
- 闸北网站建设多少钱?全面解析与预算规划
- 辽宁企业网站优化怎么做电话营销