分享CSS两列布局实现方式的总结

这篇文章主要介绍了css两列布局实现方式的总结,讨论了包括absolute + margin和float + margin方式的一些实践和问题,需要的朋友可以参考下

两列布局大概是最经典的一种网页布局方式了,本博客就是采用的这种布局。两列布局中,以主列(main)是自适应宽度,子列(sidebar)是固定宽度的情形最为常见。
今天就来好好探讨一下如何实现这种定宽+自适应的两列布局。

1. absolute + margin 方式

首先想到的是利用 absolute + margin 的方式实现。先看看代码:

主列

.container {    position: relative;   }   .sidebar {    position: absolute;    top: 0;    left: 0;    width: 200px;    height: 300px;    background-color: rgba(255, 0, 0, .5);   }   .main {    height: 300px;    margin-left: 210px;    background-color: rgba(0, 255, 0, .5);   }

立即学习“前端免费学习笔记(深入)”;

该方式利用 position 让 sidebar 列脱离文档流,然后通过 main 列的 margin-left 移除被 sidebar 列覆盖的部分。如此,我们就实现了定宽 + 自适应的两列布局。

(1)列顺序调整

在不修改 HTML 的情况下,只需简单修改 CSS,我们可以让左右两列顺序互换,来看代码:

.sidebar {    position: absolute;    top: 0;    rightright: 0;   }   .main {    margin-right: 210px;   }

立即学习“前端免费学习笔记(深入)”;

(2)主内容列优先显示

让我们考虑的更完美一点,可不可以把 main 列放 sidebar 列 的前面,使主要内容优先加载渲染? Let us try!

主列

立即学习“前端免费学习笔记(深入)”;

做上面的简单调整即可,CSS不需要任何修改!

(3)问题所在

虽然这种方式的优点很多,但是却存在一个致命缺点。因为 sidebar 列脱离了文档流,当 sidebar 列比 main 列高时会覆盖后面的布局:问题demo。
如果在 container 容器上 添加 overflow:hidden 就会使 sidebar 溢出部分被裁减。在这种布局方式下,这个问题确实没有有效的解决办法。

2. float + margin 方式

然后想到的就是 float + margin 来实现两列布局,首先实现左栏定宽,主内容自适应的两栏布局。代码如下:

主列

.sidebar {    float: left;    width: 200px;    height: 300px;    background-color: rgba(255, 0, 0, .5);   }   .main {    height: 300px;    margin-left: 210px;    background-color: rgba(0, 255, 0, .5);   }

立即学习“前端免费学习笔记(深入)”;

这种实现方式比较简单,首先把子列浮动到左边,然后在主列上设置 margin-left 为子列留出显示空间即可。

那么,这种方式支不支持调换列的位置呢?当然可以。CSS代码如下:

.sidebar {    float: rightright;    width: 200px;    height: 300px;    background-color: rgba(255, 0, 0, .5);   }   .main {    height: 300px;    margin-right: 210px;    background-color: rgba(0, 255, 0, .5);   }

立即学习“前端免费学习笔记(深入)”;

问题所在:

看起来 float + margin 方式是个好办法,然而我们前面提到过的主列在前优先显示的优化却不能实现。

3. float + 负margin 方式

废话不多说,直接上代码:

主列

.main-wrapper {    float: left;    width: 100%;   }   .main {    height: 100px;    margin-left: 210px;    background-color: rgba(255, 0, 0, .5);   }   .sidebar {    float: left;    width: 200px;    height: 100px;    margin-left: -100%;    background-color: rgba(0, 255, 0, .5);   }

立即学习“前端免费学习笔记(深入)”;

大家应该都看出来了,这就是双飞翼布局,主列优先显示。实现的过程如下:

首先浮动 main 列和 sidebar 列,然后通过 负margin 正确定位 sidebar 列。
把 main 列嵌套在一个 p 里,该 p 的宽度值设为100%。
最后通过设置 main 列的 margin-left 消除被 sidebar 覆盖的部分即可。

以上就是分享CSS两列布局实现方式的总结的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1607820.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月23日 21:10:13
下一篇 2025年12月17日 16:53:29

相关推荐

  • 详解CSS在固定宽高的div内实现垂直居中的实例分享

    这篇文章主要介绍了css在固定宽高的p内实现垂直居中的实例详解,即在p内部元素相对于p垂直居中的方法,需要的朋友可以参考下 需求案例 案例是这样的,一个外层p,高宽是固定的,但是里面内容不是固定的。很多朋友的做法是头部加一个padding或者margin,这样,里面内容显得貌似是居中了,但是假如内容…

    好文分享 2025年12月23日
    000
  • CSS3 animation实现逐帧动画效果示例介绍

    这篇文章主要介绍了css3 animation实现逐帧动画效果示例介绍,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 css3里面的animation属性非常强大,但是自己用的比较少,最近有次面试就刚好被问到了,趁现在有时间就对animation做一个小总结。同时实现一个逐帧动画的demo作为练…

    2025年12月23日 好文分享
    000
  • css全屏背景图片设置django加载图片路径详细说明

    下面小编就为大家带来一篇css全屏背景图片设置,django加载图片路径详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 css全屏背景图片设置,django加载图片路径详解 #bg { position:fixed; top:0; left:0; width:10…

    好文分享 2025年12月23日
    000
  • CSS的Display属性可能的值的说明

    下面小编就为大家带来一篇浅谈CSS的Display属性可能的值。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧none 此元素不会被显示。 block 此元素将显示为块级元素,此元素前后会带有换行符。 inline 默认。此元素会被显示为内联元素,元素前后没有换行符。 …

    好文分享 2025年12月23日
    000
  • CSS样式之背景、文本的详细介绍

    一、背景 1、背景颜色用background-color属性,例如:body{background-color:red} 2、用图像做背景用background-image属性,例如body{background-image:ul1(23.jpg) 3、背景由图片重复平铺用backgroud-rep…

    好文分享 2025年12月23日
    000
  • CSS单位和值与样式设置技巧分享

    一、单位和值    1.1 颜色值   在网页中的颜色设置是非常重要,有字体颜色(color)、背景颜色(background-color)、边框颜色(border)等,设置颜色的方法也有很多种:   1、英文命令颜色   前面几个小节中经常用到的就是这种设置方法: p{color:red;}   …

    2025年12月23日
    000
  • 分享纯CSS实现鼠标悬停显示图片效果的实例

    这里来给大家推荐一个纯css实现鼠标悬停显示图片效果的实例分享,以针对鼠标移到tr标签上来添加hover这种最简单的方式来演示,简单明了,需要的朋友可以参考下 最近在做一个网盘的项目,用到了鼠标移上去效果,这个效果可以用js来实现,今天主要分享一下,这个效果如何用纯css实现! 效果如下图: htm…

    2025年12月23日
    000
  • 浅谈css清除浮动clearfix和clear的用法介绍

    下面小编就为大家带来一篇浅谈css清除浮动(clearfix 和clear)的用法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 本文主要是讲解如何在 html 中使用 clearfix 和 clear,针对那些刚开始了解 css 的童鞋。关于 clearfix 和 …

    好文分享 2025年12月23日
    000
  • 详解CSS中的percentage百分比值使用方法

    一起来了解css中的percentage百分比值使用方法 百分比值是CSS中设计各种元素尺寸以及页面布局的基础手段,这里就带大家来彻底掌握CSS中的percentage百分比值使用,包括percentage转px的方法等,here we go~ 百分比旨在相对于父元素的相同属性的大小。如果用来设置字…

    2025年12月23日
    000
  • CSS中的选择器优先级顺序的详细介绍

    特殊性是什么 在对一个HTML元素应用CSS样式时,常常有很多种方法可以找到元素,比如: 这是一个段落 #container p { color:red } p p { color:green } p { color:yellow } 可见,如果要作用到一个HTML元素的方法有很多,远远不止这些。那…

    好文分享 2025年12月23日
    000
  • 在CSS中Box Model盒模型中的边距图文详解

    盒模型由以下css属性组成: 0.内容(content)1.padding 内边距2.border 边框3.margin 外边距下面有一个最常见的例子,虚线不属于盒模型,用于标识范围。 .box { width: 200px; height: 200px; background-color: gre…

    2025年12月23日
    000
  • 详解Less框架中将CSS强制打包到单个文件中的技巧

    在使用less预编译框架时我们总是希望能高效管理css文件的部署结构,这里我们就来看一个在less框架中将css强制打包到单个文件中的技巧,需要的朋友可以参考下 less 在import 其它less文件的时候会将其合并到单个文件中。但是当引入css 文件时,默认不会将css 合并进来 。使用inl…

    好文分享 2025年12月23日
    000
  • CSS的box-align属性控制子元素布局实例分析

    box-align 说明 box-align属性, 指定元素内子要素纵方向排列指定时使用。容器元素比子元素大很多的情况下,使用box-align属性,可以指定子元素的排序顺序,并且可以指定子元素如何表示。还有,纵方向排列一说,可以解释为元素内子元素的配置方向默认值为水平,使用此属性后垂直方向进行排列…

    2025年12月23日
    000
  • 详解CSS绘制三角形箭头图案技术解析

    最近我想修改一下这个网站,我想在上面放置一个提示框。这是很容易,但我想让提示框上有一个三角形的箭头。可是,一想到这需要使用图片,并且各种颜色,各种方向的箭头要准备无数种,这几乎是一种灾难。幸运的是,mootools的核心开发着darren waddell告诉了我一个非常棒的技术:用css绘制三角形箭…

    好文分享 2025年12月23日
    000
  • CSS实现商品图片点击放大效果的方法

    本文实例为大家分享了纯css实现图片点击放大带关闭按钮的图片特效代码,效果非常棒,供大家参考,具体内容如下 源码下载、演示 实现代码: CSS代码: .product { width:320px; height:150px; border:1px solid #ddd; margin:0 auto;…

    2025年12月23日
    000
  • 使用CSS的@supports标记来检测浏览器的兼容情况分析

    @supports可以用来检查浏览器是否支持某css属性,并且可以通过javascript进行控制,以下就来详细说明使用css的@supports标记来检测浏览器的兼容情况的方法 CSS @supports标记在CSS代码里跟@media查询语句的语法相似: @supports(prop:value…

    好文分享 2025年12月23日
    000
  • 详解CSS的overflow属性防止float撑开div的使用方法

    我们在使用float设定浮动元素的时候经常会遇到撑破p的情况,其中一种解决方法即是利用overflow: hidden,这里我们就来看一下使用css的overflow属性防止float撑开p的方法: 许多应征前端工程师的人,在面试时都会被问到这类float的问题。例如:p元素内的两个子元素p都flo…

    2025年12月23日
    000
  • CSS下拉菜单简单制作方法介绍

    本文实例为大家分享了css下拉菜单的具体实现代码,供大家参考,具体内容如下 下拉菜单实例 .dropdown { position: relative; display: inline-block; } .dropdown-content { display: none; position: abs…

    2025年12月23日
    000
  • CSS中的table-cell属性使用实例

    先让我们来研究下table,那些年曾经使用的table布局为何如此辉煌荡漾呢?她的特点有哪些呢?抛弃table的兼容性、seo、加载等与本文无关的内容不谈,只看属性,那么就两个特点: 1.同行等高。2.宽度自动调节。那么table-cell是不是具备这个特点呢?答案是yes,为什么呢?css中有一个…

    2025年12月23日 好文分享
    000
  • CSS的table-cell属性实现左图右文的排版方法示例介绍

    一些情况下使用table-cell比float来得更加简单有效,比如水平菜单的样式编写,这里我们则来看一下使用css的table-cell属性实现左图右文的排版方法详解: 对要素进行横向排列的时候,一般都会使用float, display:inline-block等方法。我们使用table-cell…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信