1、居中问题
div里的内容,ie默认为居中,而ff默认为左对齐。
使ff内容居中的方法是增加代码margin:auto;
eg: body{margin:0 auto;}
1、高度问题
设有两横行div排列,上面的div设置高度(height),如果div里的实际内容大于所设高度,在ff中会 出现两个div重叠的现象;但在ie中,下面的div会自动给上面的div让出空间。所以为避免出现层的重叠,高度一定要控制恰当,或者干脆不写高度,让 他自动调节。
或者设置:overflow:hidden
(如果要自动调节,ie7和ff会认最小高度min-height,但是ie6不认,所以为ie6加上_height:300;)[有点同6]
3、clear:both; [万能]
拿footer为例,有时候如果上面使用了float控制的n列的布局,那么在用ff浏览时footer很有可能会到处乱动——因为他还在受到浮动(float)的控制。如果想让它正常显示,在footer的div中写入clear:both;就可以达到效果了!
(或者可以自定义一个block,调整两个div的间距 eg: .block{height:5px;clear:both;font-size:1px;margin:0 auto;} )
4、浮动ie产生的双倍距离
#box{
float:left;
width:100px;
margin:0 0 0 100px; //这种情况之下IE会产生200px的距离
display:inline; //使浮动忽略
}
5、display:block,inline两个元素 display(显示)
display:block; //可以为内嵌元素模拟为块元素 常用竖向导航
display:inline; //实现同一行排列的的效果 常用于横向导航制作中
diplay:table; //for ff,模拟table的效果
Display:block元素的特点是:总是在新行上开始
高度,行高以及顶和底边距都可控制; //用line-height控制
宽度缺省是它的容器的100%,除非设定一个宽度
<div>, <p>, <h1>, <form>, <ul> 和 <li>是块元素的例子。
display:inline就是将元素显示为行内元素.
inline元素的特点是:
和其他元素都在一行上;
高,行高及顶和底边距不可改变;
宽度就是它的文字或图片的宽度,不可改变。
<span>, <a>, <label>, <input>, <img>, <strong> 和<em>是inline元素的例子。
6、IE与FF宽度和高度的问题
min -width是个非常方便的CSS命令,它可以指定元素最小也不能小于某个宽度,这样就能保证排版一直正确。整体最窄770px,最宽1024px,也就 是说窗口小于770xp就出底部滚动条,如果大于1024px自动屏幕居中。IE不认得min-这个定义,但实际上它把正常的width和height当 作有min的情况来使。这样,如果只用宽度和高度,正常的浏览器里这两个值就不会变,如果只用min-width和min-height的话,IE下面根 本等于没有设置宽度和高度。
CSS这样设计:
#container{
min-width: 600px;
width:expression_r(document.body.clientWidth < 600? "600px": "auto" );
}
第一个min-width是正常的;但第2行的width使用了Javascrīpt,这只有IE才认得,这也会让你的HTML文档不太正规。它实际上通过Javascrīpt的判断来实现最小宽度。
同样的办法也可以为IE实现最大宽度:
#container
{
min-width: 600px;
max-width: 1200px;
width:expression_r(document.body.clientWidth < 600? "600px" : document.body.clientWidth > 1200? ”1200px“ : ”auto";}
7、FF: 支持 !important, IE 则忽略
可用 !important (例:height:30px!important; height:26px;)为 FF 特别设置样式
div 的垂直居中问题: vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行
cursor: pointer 可以同时在 IE FF 中显示游标手指状, hand 仅 IE 可以
FF: 链接加边框和背景色,需设置 display: block, 同时设置 float: left 保证不换行(背景图片需要设置 float: left )。参照 menubar, 给 a 和 menubar 设置高度是为了避免底边显示错位, 若不设 height, 可以在 menubar 中插入一个空格
在FF和IE中的BOX模型解释不一致导致相差2px解决方法:
div{margin:30px!important;margin:28px;}
注意这两个margin的顺序一定不能写反,!important这个属性IE不能识别,但别的浏览器可以识别。所以在IE下其实解释成这样:
div{maring:30px;margin:28px}
重复定义的话按照最后一个来执行,所以不可以只写margin:XXpx!important;
在Firefox/Mozilla 浏览器中,对象的实际宽度= (margin-left) + (border-left-width) + (padding- left) + width + (padding-right) + (border-right-width) + (margin-right);而在IE/Opera浏览器中,对象的实际宽度 = (margin-left) + width + (margin-right)。
构架中的兼容性
1、解决超链接访问过后hover样式不显示的问题
改变CSS属性的排列顺序: 先后顺序标准应为:a:link—a:visited—a:hover—a:active
2、Li中内容超过长度后以省略号显示的方法
<meta content="text/html; charset=gb2312" http-equiv="Content-Type" />
<style type="text/css">
<!--
li {
width:200px;
white-space:nowrap; //定义列表不进行换行
text-overflow:ellipsis; //裁剪过长的文字同时添加“...” 但ff不认
-o-text-overflow:ellipsis;
overflow: hidden;}
-->
</style>
<ul>
<li><a href="#">web标准常见问题大全web标准常见问题大全</a></li>
<li><a href="#">web标准常见问题大全web标准常见问题大全</a></li>
</ul>
3、解决IE不能正确显示透明PNG——header内加入代码
function correctPNG()
{
for(var i=0; i<document.images.length; i++)
{
var img = document.images[i]
var imgName = img.src.toUpperCase()
if (imgName.substring(imgName.length-3, imgName.length) == "PNG")
{
var imgID = (img.id) ? "id='" + img.id + "' " : ""
var imgClass = (img.className) ? "class='" + img.className + "' " : ""
var imgTitle = (img.title) ? "title='" + img.title + "' " : "title='" + img.alt + "' "
var imgStyle = "display:inline-block;" + img.style.cssText
if (img.align == "left") imgStyle = "float:left;" + imgStyle
if (img.align == "right") imgStyle = "float:right;" + imgStyle
if (img.parentElement.href) imgStyle = "cursor:hand;" + imgStyle
var strNewHTML = "<span " + imgID + imgClass + imgTitle
+ " style=\"" + "width:" + img.width + "px; height:" + img.height + "px;" + imgStyle + ";"
+ "filter:progid:DXImageTransform.Microsoft.AlphaImageLoader"
+ "(src=\'" + img.src + "\', sizingMethod='scale');\"></span>"
img.outerHTML = strNewHTML
i = i-1
}
}
}
window.attachEvent("onload", correctPNG);
</script>
div{margin:30px!important;margin:28px;}
注意这两个margin的顺序一定不能写反。根据上面提到的IE并不支持!important,所以在IE下其实解释成这样:
div{maring:30px;margin:28px}
重复定义的话按照最后一个来执行,所以不可以只写margin:XXpx!important;
a:focus{-moz-outline-style:none;} //针对ff
a,area{blr:expression_r(this.onFocus=this.blur());} //针对ie 去点图片链接的虚线
6、ie6对line-height的失效
在ie6中,当文字和img、input、textarea、select、object等对象在同一个容器中的时候,line-height属性失效。只有全文字时,line-height属性才有效。
可以在其中一个非文字的对象的样式中增加: margin: (容器的line-height - 对象本身的高度)/2px 0; vertical-align:middle; 解决问题。
在IE中一般用js:obj.onselectstart=function(){return false;}
而ff用CSS:-moz-user-select:none;
IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60)。
FF:opacity:0.6;
11.用css控制图片大小
max-width:500px; //最大宽度为500
width:expression_r(this.width>500?"500px":this.width+"px"); //图片超过500,以500的宽度显示,
小于500则按原图大小显示
IE6 专用
_height: 100px;
IE6 IE7 共用
*height: 100px;
IE7 专用
*+height: 100px;
所以IE6、7、8 共用
height: 100px\9; (可以直接把ie和ff区别开)
IE7 FF 共用
height: 100px !important;
最新的ie8 可以直接把它打回ie7来显示
<meta http-equiv="X-UA-Compatible" content="IE=7"/>
css文字简写规律
font-weight:bold; //宽度
font-style:italic; //样式斜体
font-varient:small-caps; //这个属性对中文字没有影响,是规定英文字母的大小
font-size:1em; //大小
line-height:1.5em; //行高
font-family:verdana,sans-serif; //字体
但也可以把它们全部写到一行上去:
font: bold italic small-caps 1em/1.5em verdana,sans-serif;
这种简写方法只有在同时指定font-size和font-family属性时才起作用。而且,如果你没有设定font-weight, font-style, 以及 font-varient ,他们会使用缺省值
相关推荐
本文将根据多年的实践经验以及网上收集到的经验分享,整理总结常见的CSS兼容性问题,并提供相应的解决方案。 #### 二、CSS垂直居中问题 **问题描述**:在进行布局设计时,经常会遇到元素垂直居中的需求。但在实际...
进行跨浏览器测试,确保兼容性。 **总结** CSS Sprites生成工具,如CSS Satyr v1.2.exe,为优化网页加载性能提供了便利。它们简化了CSS Sprites的制作流程,让设计师和开发者能够更高效地管理和使用网页图像,同时...
在实际开发中,还需要了解各种工具和技巧,如Photoshop切图技巧、CSS预处理器的使用、浏览器兼容性处理、性能优化等。这些知识点为前端开发者提供了强大的工具箱,帮助他们构建出美观、高效、易维护的网页。
【描述】提到的“关于css的bug的解决”意味着这些文章会深入探讨CSS在实际应用中可能出现的问题,如浏览器兼容性问题,以及如何有效地调试和修复这些问题。此外,“一些很多人都不注意的细节方面”暗示了文章可能...
3. 兼容性考虑:好的CSS模板会考虑不同浏览器的兼容性,确保在各种环境下都能正常显示。 三、CSS菜单进阶技巧 1. 悬停效果:通过CSS的`:hover`伪类,我们可以为菜单项添加悬停效果,如改变背景色、显示下拉子菜单...
CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理方法并 整理了一下.对于web2.0的过度,请尽量用xhtml格式写代码,而且DOCTYPE 影响 CSS ...
- **网页布局**:采用DIV+CSS的布局方式,这是一种主流的网页布局方法,能够兼容各大主流浏览器,提供稳定的显示效果。 - **网页编程语言**:使用HTML5+CSS3+JavaScript完成网站的功能设计,确保代码兼容市面上所有...
描述中提到的“可自动下载90%静态页面”,意味着这款工具的兼容性和覆盖率相当高,能够处理大多数基于HTML和CSS构建的网页。它被称为“最实用的版本”,暗示可能有多个迭代或不同的实现,而这个版本在功能和稳定性上...
此外,考虑到性能和兼容性,开发者可能需要对代码进行优化,例如使用CSS预处理器(如Sass或Less)编写更易维护的样式代码,使用Babel将ES6+语法转换为广泛支持的ES5,以及通过Webpack或Gulp等工具进行模块打包和压缩...
1. **兼容性问题**:虽然现代浏览器普遍支持这些CSS属性,但在开发过程中还是需要注意不同浏览器间的兼容性差异,确保效果的一致性。 2. **过度使用的问题**:虽然`text-transform`和`text-indent`能带来很好的...
总结来说,这个“html+js兼容性很好的留言墙源码”是一个集成了HTML布局、JavaScript交互和多浏览器兼容性的项目,它展示了前端开发中的常见技术和实践。对于想要学习网页交互开发或者需要类似功能的开发者,这是一...
总结,"收集了30个div+css网站后台模板"意味着我们可以学习到如何利用Div和CSS创建各种后台管理界面,理解并实践上述的CSS技术,包括布局、响应式设计、预处理器和框架的运用。通过分析这些模板,开发者能够提升自己...
- **多媒体处理**:项目中可能需要处理图像、视频等多媒体内容,通常会使用Photoshop等图形编辑软件进行处理,确保图片质量的同时也考虑了加载速度和兼容性。 #### 四、项目实践价值 - **教育意义**:该项目非常...
用户只需将原始CSS代码粘贴到工具中,它就会自动识别并添加相应的浏览器前缀,确保CSS样式在不同浏览器中的兼容性和一致性。官方网站:[http://prefixmycss.com/](http://prefixmycss.com/) #### 八、SkyCSSTool *...
这不仅有利于搜索引擎优化(SEO),还有助于网页在各种设备上的兼容性和适应性,包括PDA、移动电话和屏幕阅读机等。 总结起来,《DIV+CSS布局入门》教程旨在引导初学者从结构化思维出发,掌握CSS布局的基本原则和...
- **素材选择**: 收集各大平台的高质量图片素材, 并使用Photoshop等工具进行处理, 以适应网页尺寸。 - **文件管理**: - HTML文件: 包含首页(index.html)和其他二级页面。 - CSS文件: 控制网页的整体样式, 包括文字...
在这个项目里,使用了DIV+CSS布局方式来构建网页,确保了页面的响应式和兼容性。 - **JavaScript**:一种脚本语言,常用于实现网页的交互功能,比如动态轮播特效、表单验证等。此项目中,部分网页加入了JS特效来...