• 博客园logo
  • 会员
  • 周边
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
阳光Angel
博客园    首页    新随笔    联系   管理    订阅  订阅
overflow属性-摘自网友
 
  • 关于我们
  • 版权声明
  • 网站地图

前端观察

专注于网站前端设计与前端开发

用IE6抢不到火车票的!!!

  • Home 首页
  • CSS样式之美
  • Front News前端资讯
  • JavascriptAjax与JS技术
  • Resource前端资源
  • ShowCase优秀设计与界面展示
  • Tips前端技巧
您的位置:首页 > CSS, Tips > CSS Overflow 属性

CSS Overflow 属性

神飞 发表于 08. Aug, 2009, 分类: CSS, Tips , 13 条评论 »
标签:css & overflow & 浏览器
原文:CSS Overflow 属性
译自:The CSS Overflow Property
版权所有,转载请注明出处,多谢!!

 


根据CSS的盒模型概念,页面中的每个元素,都是一个矩形的盒子。这些盒子的大小、位置和行为都可以用CSS来控制。对于行为,我的意思是当盒子内外的内容改变的时候,它如何处理。比如,如果你没有设置一个盒子的高度,该盒子的高度将会根据它容纳内容的需要而增长。但是当你给一个盒子指定了一个高度或宽度而里面的内容超出的时候会发生什么?这就是该添加CSS的overflow属性的时候了,它允许你设定该种情况下如何处理。

overflow属性有四个值:visible (默认), hidden, scroll, 和auto。同样有两个overflow的姐妹属性overflow-y 和overflow-x,它们很少被采用。

让我们分别看一下这几个值,并讨论一写共同用法和技巧。

Visible

如果你不设置overflow属性,则默认的overflow属性值就是visible。所以一般而言,并没有什么理由特别的设定overflow的属性为visible除非你想覆盖它在其它地方被设定的值。

这里需要记住的重要的事情是,尽管盒子外面的内容是可见的,内容并不会影响页面的工作流。比如:

一般来说,你至少不用为里面的内容为文字的盒子设置固定的高度,这样就不会遇到这种情况了。

Hidden

默认值visible的相反的值就是hidden。它会将所有超出盒子的所有内容都给隐藏掉。

这对应付使用动态的内容,而且可能会由于内容溢出而引起一些布局上的问题的确很有用。尽管如此,请记住用此方法隐藏的内容将彻底的看不到(除非去查看源代码)。 比如有的用户设置他们的浏览器的默认字体比你预期的要大些,你会将一些文字推到盒子的外面然后完全的隐藏之……

Scroll

设置一个盒子的overflow值为scroll将会隐藏掉渲染到盒子之外的内容,但是它将会提供一个滚动条在盒子内部滚动,从而可以查看剩下的内容。

值得注意的是,使用scroll将会同时产生水平和垂直两个滚动条,就算内容只需要其中一个。

Auto

overflow的auto值很像scroll,它唯一解决的是在你不需要的时候也会出现滚动条的问题。

清除浮动

设置overflow的一个更流行的用处是,说也奇怪,清除浮动。设置overflow并不会在该元素上清除浮动,它将清除自己(self-clear)。意思就是,应用了overflow(auto或hidden)的元素,将会扩展到它需要的大小以包围它里面的浮动的子元素(而不是叠了起来(collapsing)),假设未定义高度。就像这样:

对于此问题,经过测试,IE6会自动扩展父层元素的高度,而IE8和FF等浏览器加上overflow:auto后,即可清除浮动。——神飞

这里有更多关于浮动的细节文章关于浮动的一切。

跨浏览器的烦恼

就像CSS中的很多东东,overflow有很多的跨浏览器的蹊跷的事情。比如这些:

滚动条在盒子里面还是外面?

Firefox将其放到盒子外面,而IE则将其放到里面。我认为只有IE是对的(它应该在里面的)。

看清楚这个明显的不同。

IE 8 扩展盒子的bug

IE8有很多有趣的新bug,包括一些非常严重的隐藏在网页中的。这里有更多的关于IE8的overflow的bug的介绍。

破坏浮动布局

IE 6, 7 和 8都会扭曲默认的overflow visible值并将水平的扩展一个盒子一匹配内容(比如图片)。 这对使用浮动列布局的结构非常痛苦,而且单个扩展的列就能够将其它列挤下去并使布局乱掉!


事实上,这个我在验证的时候发现,只有IE6才会出现这种情况,而IE7、IE8和其它浏览器表现一致。如果大家在使用IE7或IE8时有遇到这种情况,请告诉我,多谢!——神飞

滚动条能用CSS控制吗?

IE过去在较老的版本中允许这样,但是之后就收敛了。比如许多表单元素,滚动条就不允许使用CSS控制。我在它是否是件好事情上没有任何具体的意见,但是我可以说,在网站的所有内容上使用滚动条是很丑陋的和俗气的。如果你需要一个美化的滚动条,你或许需要寻找JavaScript来模拟。

IE 技巧

无论是否需要,IE都会一直显示一个垂直的滚动条,这对预防水平跳动是有些作用的,但并非总是可取的。要想在IE中移除它,可以在body元素中设置overflow为auto。PS:此种情况也较少发现,不过在body的样式中添加overflow:auto的方法,建议考虑采用——神飞

演示

本文的演示页面,可以查看这个页面。

作者: 神飞
爱好前端设计与开发,崇尚一目了然的设计。现居深圳,就职于腾讯ISUX团队 Follow me on twitter @qianduan。
如果你喜欢本文,欢迎 订阅本站 以获得本站最新内容。

您或许也会喜欢:

  • Firefox 4 beta 1发布——前端开发者须知
  • 兼容所有浏览器的CSS3圆角
  • CSS3系列教程:简介
  • 主流浏览器版本发布历史
  • 用Javascript修正12个常见的浏览器问题
  • CSS在Internet Explorer 6, 7 和8中的差别
  • http://www.qianduan.net/high-performance-web-site-do-not-use-import.html
  • 7个新鲜的测试浏览器兼容性的简单方法
  • RGBa色彩的浏览器支持
  • 视觉手册:CSS在IE6,IE7和IE8中的兼容性

13 个评论

  • 喜欢 发表于Aug 9, 2009 at 11:07

    学习了,谢谢

    回复
  • nic 发表于Aug 9, 2009 at 17:40

    讲解的非常不错

    回复
  • jacky 发表于Nov 27, 2009 at 16:25

    thank you

    回复
  • creak 发表于Apr 7, 2010 at 15:15

    思路相当清晰

    回复
  • Angela 发表于Apr 20, 2010 at 10:12

    字写得真不错~

    回复
  • ZhouQi 发表于Apr 29, 2010 at 21:58

    ie7的visible在某些情况下有bug,比如子元素为inline元素,该元素有上下padding,这个时候子元素的背景并不会overflow到父元素的外面去
    不过我也没弄清到底是“上下padding”的bug还是“overflow:visible“的bug,过两天做个demo再试试

    回复
  • 网友 发表于Jun 24, 2010 at 02:36

    之讲解了问题之所在,却没说如何解决问题。比如ie6的overflow:visible bug!

    回复
    • 海玉 发表于Apr 18, 2011 at 15:16

      ie6的visible bug似乎是这么解决的,外层元素使用overflow:hidden,然后子元素使用position:relative,这样可以达到ie6下呈现overflow:visible;的效果。但是我纳闷的是OOCSS下的template.css为什么这么写.body{overflow:hidden; _overflow:visible; _zoom:1;} 这个_zoom:1还好理解ie6下让.body元素触发Haslayout,这个_overflow:visible是什么意思,ie6下overflow默认不是visible?帮忙解答下吧,神飞。

      回复
  • gylpm 发表于Sep 2, 2010 at 20:59

    【滚动条在盒子里面还是外面?

    Firefox将其放到盒子外面,而IE则将其放到里面。我认为只有IE是对的(它应该在里面的)。】

    怎么改正Firefox的滚动条放置在盒子里面啊?

    回复
  • 锋华 发表于Sep 25, 2010 at 15:25

    『这里需要记住的重要的事情是,尽管盒子外面的内容是可见的,内容并不会影响页面的工作流。』

    这句话欠妥,在visible的情况下,只有ie7会这么干,ie6自动延展父元素,ie8和标准浏览器都将超出的内容在正常的文档流里面显示出来,不会重叠覆盖。

    回复
    • 锋华 发表于Sep 25, 2010 at 15:28

      原来我说的也不全面,在子元素是float的情况下,如我所说;在子元素非float情况下,如你所说。

      回复
  • Tian 发表于Jul 24, 2012 at 14:12

    geilivable

    回复
  • foreverlone@foxmail.com 发表于Apr 12, 2013 at 11:48

    学习饿了 字体真不错 可以发我邮箱一份吗 谢谢了

    回复

发表评论

取消回复

微信上关注我们


请扫描上面的二维码
或者在微信中搜索"iqianduan"添加好友

推荐微信机器人高级版

热门文章

  • LESS/Sass/CoffeeScript编译工具推荐 – Koala
  • 扁平化设计美学
  • Chrome 28发布——hello Blink
  • 移动端webapp开发必备知识
  • 扁平化网页设计展示
  • 有用的:nth-child秘方
  • CSS实现垂直居中的5种方法
  • 【校园招聘】腾讯ISUX招募前端开发实习生
  • HTML5 中 div section article 的区别
  • 腾讯ISUX急招前端开发
  • 前端界网站上线
  • 明天的CSS
  • font-face在移动终端的支持
  • 别了,Presto,Opera新版本将采用Webkit内核
  • 你需要知道的CSS3 动画技术
  • 60多个超炫的视差滚动效果网站设计欣赏
  • iPhone 5/iOS 6前端开发指南
  • Zen Coding: 一种快速编写HTML/CSS代码的方法
  • CSS简写指南
  • 关于z-index的那些事儿

友情链接

  • 99CSS
  • CSS HOUSE
  • CSS9.NET
  • CSS库吧
  • GaoWhen高H温
  • GBin1
  • Hiro技术站
  • ibaoland
  • IE浏览器
  • learntome
  • Linode VPS
  • poor
  • Smallni's blog
  • suta
  • Time Machine
  • V2EX
  • Web 标准化交流会
  • WEB前端开发
  • WhyIDC 双线全能空间
  • 中文最佳网站设计
  • 前端博客导航
  • 前端界
  • 启良工作室
  • 堂主
  • 大猫の意淫网志
  • 我爱互联网
  • 我爱水煮鱼
  • 笨笨剥壳
  • 米随随s5s5
  • 腾讯AlloyTeam
  • 芒果
  • 裁纸刀下
  • 觉唯前端
  • 车周边
  • 软件开发网
  • 进步博客
  • 飘飘的生活空间
  • 黄老湿

Meta

  • Log in
  • Entries RSS
  • Comments RSS
  • WordPress.org

Powered by Wordpress
Copyright © 2008-2012 前端观察 All rights reserved.

  • 关于我们
  • 版权声明
  • 网站地图
posted on 2013-07-15 11:26  xiaoleilei  阅读(344)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3