iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >css怎么实现中间自适应布局
  • 416
分享到

css怎么实现中间自适应布局

2023-06-08 07:06:25 416人浏览 薄情痞子
摘要

本篇文章为大家展示了CSS怎么实现中间自适应布局,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。问题:如何实现三栏布局(高度固定,左中右的结构)假设高度已知,请写出三栏布局,其中左右宽度均为300px

本篇文章为大家展示了CSS怎么实现中间自适应布局,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

问题:如何实现三栏布局(高度固定,左中右的结构)

假设高度已知,请写出三栏布局,其中左右宽度均为300px,中间自适应。

看了上面的题目,有经验的人也许会觉得很简单,仔细想想,如果我们来写,能写出几种方案呢?一般都会想到两种吧,float和position定位,其实除了这两种外,还有3种可以写,下面我就来一一介绍一下:

方案一(float浮动)

<section class='layout float'>         <style>             .layout.float .left-right-center{                 height: 100px;             }             .layout.float .left{                 float: left;                 width: 300px;                 background-color: red;             }             .layout.float .right{                 float: right;                 width: 300px;                 background-color: blue;             }             .layout.float .center{                 background-color: yellow;             }         </style>         <article class="left-right-center">             <div class="left"></div>             <div class="right"></div>             <div class="center">我是中间的自适应元素--浮动</div>         </article>     </section>
  • 原理:左右两个div由于浮动脱离了文档流,center就会上移,造成三栏布局的效果(前提是高度相同)

  • 优点:兼容性高

  • 缺点:需要清除浮动来防止影响其他元素

  • 如果高度不固定,中间的内容会被撑开,左右两边不会一起撑开

方案二(绝对定位)

<section class="layout absolute">         <style>             .layout.absolute .left-center-right div{                 position: absolute;                 height: 100px;             }             .layout.absolute .left{                 left: 0;                 width: 300px;                 background-color: red;             }             .layout.absolute .center{                 left: 300px;                 right: 300px;                 background-color: yellow;             }             .layout.absolute .right{                 right: 0;                 width: 300px;                 background-color: blue;             }         </style>         <article class="left-center-right">            <div class="left"></div>            <div class="center">                我是中间的自适应元素--绝对定位            </div>            <div class="right"></div>         </article>     </section>
  • 原理:利用绝对定位以及宽度,将左右两边的div固定住,中间div的宽度就会有自适应的效果

  • 优点:快捷

  • 缺点:如果父元素脱离了文档流,子元素一定会脱离文档流,运用的场景不多

  • 如果中间元素的高度增加,两边元素的高度不会增加,所以只有中间的div会撑开

方案三(flex布局)

<section class="layout flex">         <style>             .layout.flex .left-center-right{                 display: flex;                 height: 100px;             }             .layout.flex .left{                 width: 300px;                 background-color: red;             }             .layout.flex .center{                 flex: 1;                 background-color: yellow;             }             .layout.flex .right{                 width: 300px;                 background-color: blue;             }         </style>         <article class="left-center-right">            <div class="left"></div>            <div class="center">                我是中间的自适应元素--flex布局            </div>            <div class="right"></div>         </article>     </section>
  • 原理:将父元素设置为flex布局,然后中间元素设置flex为1,达到自适应的效果

  • 优点:在实际开发中常用

  • 缺点:IE8及以下的浏览器不支持

  • 如果高度不固定,中间内容的高度撑开后,两边也会随之撑开

方案四(table布局)

   <section class="layout table">        <style>            .layout.table .left-center-right{                display: table;                height: 100px;                width: 100%;            }            .layout.table .left{                display: table-cell;                width: 300px;                background-color: red;            }            .layout.table .center{                display: table-cell;                background-color: yellow;            }            .layout.table .right{                display: table-cell;                width: 300px;                background-color: blue;            }        </style>        <article class="left-center-right">            <div class="left"></div>            <div class="center">                我是中间的自适应元素--table            </div>            <div class="right"></div>        </article>    </section>
  • 原理:将父元素设置为table布局,然后每个子元素都是teble-cell,给左右两个格子设置固定的宽度,中间的格子就可以达到自适应的效果

  • 优点:兼容性好,可做flex布局在ie8以下的代替

  • 缺点:局限性

  • 如果高度不固定,中间被撑开时,左右两边也会被撑开,和flex类似

方案五(网格布局)

<section class="layout grid">        <style>            .layout.grid .left-center-right{                display: grid;                width: 100%;                grid-template-rows: 100px;                grid-template-columns: 300px auto 300px;            }                        .layout.grid .left{                background-color: red;            }            .layout.grid .center{                background-color: yellow;            }            .layout.grid .right{                background-color: blue;            }        </style>        <article class="left-center-right">            <div class="left"></div>            <div class="center">                我是中间的自适应元素--grid布局            </div>            <div class="right"></div>        </article>    </section>
  • 原理:将父元素设置为网格布局,然后规定每格的高度以及每格的宽度,只用分别给每格单独设置颜色即可

  • 优点:技术比较新,方便

  • 缺点:兼容性不是很好

  • 如果高度不固定,中间元素添加文本,也不会撑开

上述内容就是css怎么实现中间自适应布局,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网精选频道。

--结束END--

本文标题: css怎么实现中间自适应布局

本文链接: https://www.lsjlt.com/news/252561.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • css怎么实现中间自适应布局
    本篇文章为大家展示了css怎么实现中间自适应布局,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。问题:如何实现三栏布局(高度固定,左中右的结构)假设高度已知,请写出三栏布局,其中左右宽度均为300px...
    99+
    2023-06-08
  • 使用css怎么实现两边固定中间自适应布局
    这篇文章将为大家详细讲解有关使用css怎么实现两边固定中间自适应布局,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。浮动<style type="text/css&q...
    99+
    2023-06-08
  • CSS实现三列布局两端固定宽度中间自适应
    这篇文章主要讲解了“CSS实现三列布局两端固定宽度中间自适应”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS实现三列布局两端固定宽度中间自适应”吧! ...
    99+
    2024-04-02
  • CSS怎么实现独行DIV自适应宽度布局
    这篇文章主要介绍了CSS怎么实现独行DIV自适应宽度布局的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇CSS怎么实现独行DIV自适应宽度布局文章都...
    99+
    2024-04-02
  • 使用Rem怎么实现自适应布局
    本篇文章给大家分享的是有关使用Rem怎么实现自适应布局,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。在移动端我们一般会设置布局视口宽度=设备宽度,即内容呈现的区域在设备屏幕内。...
    99+
    2023-06-08
  • CSS中常见自适应布局是什么
    这篇文章给大家分享的是有关CSS中常见自适应布局是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。   自适应布局:   自适应布局的特点就是根据不同的设备其屏幕尺寸的大小...
    99+
    2024-04-02
  • 如何使用CSS实现三栏自适应布局
    这篇文章将为大家详细讲解有关如何使用CSS实现三栏自适应布局,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 基于传统的position和margin等属性进行布局这里也分为三种方法,分别为绝对定位法,...
    99+
    2023-06-08
  • css3自适应布局如何实现
    这篇文章主要介绍“css3自适应布局如何实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“css3自适应布局如何实现”文章能帮助大家解决问题。 ...
    99+
    2024-04-02
  • 如何实现独行DIV自适应宽度布局CSS
    这篇文章主要讲解了“如何实现独行DIV自适应宽度布局CSS”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何实现独行DIV自适应宽度布局CSS”吧!  关键...
    99+
    2024-04-02
  • 如何使用CSS实现自适应的多列布局
    随着移动设备的普及,越来越多的网站需要适应不同屏幕尺寸。使用CSS实现自适应的多列布局是一个重要的技巧,可以让你的网站在各种设备上都能够展现良好的效果。本文将介绍如何使用CSS实现自适应的多列布局,并给出具体的代码示例。一、使用Flexbo...
    99+
    2023-10-21
    自适应布局 CSS布局 多列布局
  • Vue前端项目自适应布局怎么实现
    这篇文章主要介绍“Vue前端项目自适应布局怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue前端项目自适应布局怎么实现”文章能帮助大家解决问题。一、单位尺寸px%vw、vh: 窗口em: ...
    99+
    2023-07-02
  • css如何实现六种自适应两栏布局方式
    这篇文章主要介绍css如何实现六种自适应两栏布局方式,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!html结构  <body>     ...
    99+
    2023-06-08
  • css怎么实现自适应
    这篇文章主要讲解了“css怎么实现自适应”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css怎么实现自适应”吧! 在css中,可...
    99+
    2024-04-02
  • 使用html5怎么实现移动端自适应布局
    这篇文章给大家介绍使用html5怎么实现移动端自适应布局,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。使用媒体查询,下面制定了几种适应方式,例如第一个表示屏幕宽度在320px-360px之间的,html字体大小适配为1...
    99+
    2023-06-09
  • 如何实现左右两列自适应中间列内容即随中间内容高度自适应的布局
    本篇内容主要讲解“如何实现左右两列自适应中间列内容即随中间内容高度自适应的布局”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何实现左右两列自适应中间列内容即随...
    99+
    2024-04-02
  • CSS布局技巧:实现水平对齐的自适应卡片布局的最佳实践
    在网页设计中,经常会遇到需要水平对齐的卡片布局,比如照片墙、产品展示等。如何实现一个美观且自适应的水平对齐卡片布局,是每个前端开发者关注的重点。本文将介绍一些CSS布局技巧,帮助你实现水平对齐的自适应卡片布局,并附带具体的代码示例。使用Fl...
    99+
    2023-10-21
    - CSS布局 - 水平对齐 - 自适应卡片布局
  • 怎么在css中实现响应式布局
    今天就跟大家聊聊有关怎么在css中实现响应式布局,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。响应式布局的四种方式总的html代码<body>  &n...
    99+
    2023-06-15
  • CSS怎么实现响应式布局
    小编给大家分享一下CSS怎么实现响应式布局,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!用CSS实现响应式布局响应式布局感觉很高大上,很难,但实际上只用CSS也能实现响应式布局要用的就是CSS中的没接查询,下面就介绍一下怎...
    99+
    2023-06-08
  • CSS网页响应式布局怎么实现自动适配Pc/Pad/Phone设备
    这篇文章给大家分享的是有关CSS网页响应式布局怎么实现自动适配Pc/Pad/Phone设备的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。index<!DOCTYPE html><htm...
    99+
    2023-06-08
  • flex布局如何实现每行固定数量+自适应布局
    这篇文章主要介绍flex布局如何实现每行固定数量+自适应布局,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体如下:效果展示解析 <div class="template"...
    99+
    2023-06-08
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作