关于IE低版本兼容问题
1,元素浮动之后,能设置宽度的话就给元素加宽度。如果需要宽度是内容撑开,就给它里边的块元素加上浮动;
解决方案:给需要宽度由内容撑开的元素加上浮动
css样式:
<style>
.box{
width:400px;
border: 1px solid black;
overflow:hidden;
}
.left{
float:left;
background:red;
}
.right{
float:right;
background: blue;
}
h2{
margin:0;
height:30px;
float:left;
}
</style>
html结构:
<div class="box">
<div class="left">
<h2>左边</h2>
</div>
<div class="right">
<h2>右边</h2>
</div>
</div>
2,第一块元素浮动,第二块元素加margin值等于第一块元素,在IE6下面有间隙问题;
解决方案:不建议这么写,用浮动解决
css样式:
<style>
.box{
width:500px;
}
.left{
width:200px;
height:200px;
float:left;
background:red;
}
.right{
width:200px;
height:200px;
background:blue;
margin-left:200px;
}
</style>
HTML结构:
<div class="box">
<div class="left"></div>
<div class="right"></div>
</div>
3,IE6 下子元素超出父级宽度,会把父级的宽高撑开
解决方案:子元素高度不要超过父级高度
css样式:
<style>
.box{
width:200px;
height:200px;
border: 1px soild red;
}
.item{
width:100px;
height:460px;
background-color:blue;
}
</style>
HTML结构:
<div class="box">
<div class="item"></div>
</div>
3,p标签包含块元素嵌套规则。
解决方案:p标签不要嵌套块元素
HTML结构:
<p>
<div>div</div>
</p>
4,margin 兼容性问题,父级包含的时候子级的margin-top会传递给父级,同级元素上下外边距会叠压;
解决方案:
问题1,触发haslayout, BFC.
问题2,尽量使用同一方向的margin,比如都设置top或者bottom;或者用padding代替。
css样式:
<style>
.box{
background-color:green;
}
.head{
height:30px;
background-color:red;
margin:50px;
}
.content{
height:30px;
background-color:blue;
margin:50px;
}
</style>
HTML结构:
<div class="box">
<div class="head">head</div>
<div class="content">content</div>
</div>
5,display:inline-block
解决方案:针对IE6,7使用hack添加display:inline和zoom:1
css样式:
<style>
div{
width:100px;
height:100px;
display:inline-block;
border:1px solid red;
font-size:12px;
*display:inline;
*zoom:1;
}
span{
width:100px;
height:100px;
border:1px solid red;
font-size:24px;
*display:inline;
*zoom:1;
*margin-right:-4px;
}
section{
font-size:0;
}
</style>
HTML结构:
<p>块元素转内联快</p>
<hr>
<section>
<div>快1</div>
<div>块2</div>
<div>块3</div>
</section>
<p>内联元素转内联块</p>
<hr>
<section>
<span>内联1</span>
<span>内联2</span>
<span>内联3</span>
</section>
希望能帮助大家!
关于IE低版本兼容问题的更多相关文章
- Material Designer的低版本兼容实现(五)—— ActivityOptionsCompat
extends:http://www.cnblogs.com/tianzhijiexian/p/4087917.html 本文是对API中的方法做了介绍,如果想要看如何让这些方法兼容4.x或2.x可以 ...
- Material Designer的低版本兼容实现(一)—— 简介 & 目录
很长一段时间没写东西了,其实是因为最近在研究Material Designer这个东西,熬夜熬的身体也不是很好了.所以就偷懒没写东西,这回开的这个系列文章是讲如何将Material Designer在 ...
- fetch ios低版本兼容cannot clone a disturbed response
报错信息 ios 11以下 cannot clone a disturbed response github.com/github/fetc- 问题发生场景 使用了一个或者多个三方库 三方库或者自己的 ...
- IE低版本兼容的感悟
2017-04-09 曾经折磨一代人的兼容问题,如今也在同样折磨着我们,明明可以做JS判断来避免对ie低版本的兼容,但是却还是耐心的做着兼容,你可能会问这是为什么, 我们调的不是兼容,是整整一代人的情 ...
- Material Designer的低版本兼容实现(二)—— Theme
Theme material主题可以定义为如下形式: @android:style/Theme.Material @android:style/Theme.Material.Light @androi ...
- javascript原生bind方法ie低版本兼容详解
上一篇文章讲到了javascript原生的bind方法: http://www.cnblogs.com/liulangmao/p/3451669.html 这篇文章就在理解了原生bind方法的原理以后 ...
- Material Designer的低版本兼容实现(十)—— CheckBox & RadioButton
ChekBox的用途我们就不必多说了,算是一个很古老的控件了,何其类似的还有RadioButton,这个东西因为我目前还没写出来,所以用了别人的一个lib,这下面会说到.顺便说一句,如果你的app是在 ...
- Material Designer的低版本兼容实现(十二)—— Slider or SeekBar
Slider,我更喜欢叫他SeekBar,其实是一个东西啦,就是拖动条.5.0的拖动条和4.x上的HOLO风格完全不同,平添了一些精致.此外还加入了数值指示器,让用户在滑动的时候就能知道现在到了什么位 ...
- 低版本兼容使用Fragment (转)
Fragment框架开发东西确实很方便,但是恼人的是从4.0才开始支持.以前的版本必须用兼容模式开发,本人在网上找了大量资料,终于找到些线索正常运行于2.1版本的安卓系统.现在浅说一下兼容版本使用Fr ...
- Material Designer的低版本兼容实现(十四)—— CardView
今天说的又是一个5.0中才有的新控件——CardView(卡片视图).这个东东其实我们早就见过了,无论是微博还是人人客户端,它都有出现.通常我们都是通过自定义一个背景图片,然后通过给layout进行设 ...
随机推荐
- javascript object-oriented something
http://www.ibm.com/developerworks/cn/web/1304_zengyz_jsoo/ http://www.cnblogs.com/RicCC/archive/2008 ...
- 如何设置secureCRT的鼠标右键为弹出文本操作菜单功能
secureCRT的鼠标右键功能默认是粘贴的功能,用起来和windows系统的风格不一致, 如果要改为右键为弹出文本操作菜单功能,方便对选择的内容做拷贝编辑操作,可以在 options菜单----&g ...
- webpack 学习心得(一)
Webpack 是一个模块打包器.它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源. 因为本人也正在学习webpack ,所以此篇文章比较入门. 首先你想使用webp ...
- date()中的getYear的小问题
function DateDemo(){ var d,s = "今天得日期是:"; d = new Date(); s += d.getMonth()++"/" ...
- ASP.NET Core MVC 中设置全局异常处理方式
在asp.net core mvc中,如果有未处理的异常发生后,会返回http500错误,对于最终用户来说,显然不是特别友好.那如何对于这些未处理的异常显示统一的错误提示页面呢? 在asp.net c ...
- Java多线程程序休眠、暂停与停止
休眠 在Java多线程中,可以使用sleep()方法在指定毫秒数内让当前正在执行的线程休眠. 下面这段代码,使得主函数的main线程休眠了2000ms,最后输出的间隔时间也是2000ms. p ...
- Java内部类基本使用
链接到外部类 创建内部类时,那个类的对象同时拥有封装对象(封装内部类的外部类)的一个链接,所以内部类可以访问外部类的成员. 内部类拥有对外部类所有元素的访问权限. 看如下代码,内部类SSe ...
- Sass与Compass——回顾
compass 是sass的一个工具库 compass在sass 的基础上封装了一系列有用的模块,用来补充和丰富sass的工能, 安装: compass是用 ruby语言开发的,所以安装它之前必须安装 ...
- SpringMVC中404错误解决方法总结
在新手配置Spring MVC的时候,感觉都弄好了之后,运行起来却显示404错误. 网上对出现404的问题不同情况,都有了解决方法,前几天我也遇到了这个问题,顺便把这些问题总结一下. 解决问题最重要的 ...
- VS2015中VB.NET类(dLL)里下载并读取文件
最近要从一个http上下载个文件,差点就直接telnet了,突然发现了这个: My.Computer.Network.DownloadFile("目标文件网址") 但是还得读取它, ...