iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >css中双飞翼布局和圣杯布局的示例分析
  • 870
分享到

css中双飞翼布局和圣杯布局的示例分析

2024-04-02 19:04:59 870人浏览 八月长安
摘要

这篇文章主要为大家展示了“CSS中双飞翼布局和圣杯布局的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css中双飞翼布局和圣杯布局的示例分析”这篇文章吧

这篇文章主要为大家展示了“CSS中双飞翼布局和圣杯布局的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css中双飞翼布局和圣杯布局的示例分析”这篇文章吧。

1、圣杯布局

浮动、负边距、相对定位、不添加额外标签

效果图

css中双飞翼布局和圣杯布局的示例分析

DOM结构:

<div class="header">Header</div>
<div class="bd">
    <div class="main">Main</div>
    <div class="left">Left</div>
    <div class="right">Right
    </div>
</div>
<div class="footer">Footer</div>

样式:

<style>
        body{padding:0;margin:0}
        .header,.footer{width:100%;  background: #666;height:30px;clear:both;}
        .bd{
            padding-left:150px;
            padding-right:190px;
        }
        .left{
            background: #E79F6D;
            width:150px;
            float:left;
            margin-left:-100%;
            position: relative;
            left:-150px;
        }
        .main{
            background: #D6D6D6;
            width:100%;
            float:left;

        }
        .right{
            background: #77BBDD;
            width:190px;
            float:left;
            margin-left:-190px;
            position:relative;
            right:-190px;
        }
    </style>

左中右部分样式变化过程

1、中间部分需要根据浏览器宽度的变化而变化,所以要用100%,这里设*左中右向左浮动,因为中间100%,左层和右层根本没有位置上去

  .left{
            background: #E79F6D;
            width:150px;
            float:left;
        }
        .main{
            background: #D6D6D6;
            width:100%;
            float:left;

        }
        .right{
            background: #77BBDD;
            width:190px;
            float:left;
        }

css中双飞翼布局和圣杯布局的示例分析

2、把左层负margin150后,发现left上去了,因为负到出窗口没位置了,只能往上挪

.left{ 
   background: #E79F6D; 
   width:150px; 
   float:left; 
   margin-left:-150px; 
}

css中双飞翼布局和圣杯布局的示例分析

3、那么按第二步这个方法,可以得出它只要挪动窗口宽度那么宽就能到最左边了,利用负边距,把左右栏定位

.left{ 
  background: #E79F6D; 
  width:150px; 
  float:left; 
  margin-left:-100%; 
}
.right{ 
  background: #77BBDD; 
  width:190px; 
  float:left; 
  margin-left:-190px; 
}

css中双飞翼布局和圣杯布局的示例分析

4、然而问题来了,中间被左右挡住了啊,只好给外层加padding了

.bd{ 
  padding-left:150px; 
  padding-right:190px;
}

css中双飞翼布局和圣杯布局的示例分析

5、但是加了之后左右栏也缩进来了,于是采用相对定位方法,各自相对于自己把自己挪出去,得到最终结果

.left{ 
  background: #E79F6D; 
  width:150px; 
  float:left; 
  margin-left:-100%; 
  position: relative; 
  left:-150px; 
} 
.right{ 
  background: #77BBDD; 
  width:190px; 
  float:left; 
  margin-left:-190px; 
  position:relative; 
  right:-190px; 
}

css中双飞翼布局和圣杯布局的示例分析

2、双飞翼布局

在不增加额外标签的情况下,圣杯布局已经非常完美,圣杯布局使用了相对定位,以后布局是有局限性的,而且宽度控制要改的地方也多,那么有没其他方法更加简洁方便呢?

在淘宝UED探讨下,增加多一个div就可以不用相对布局了,只用到了浮动和负边距,这就是我们所说的双飞翼布局。

DOM结构:main内层增加了一个div

<div class="header">Header</div>
<div class="bd"> 
  <div class="main"> 
    <div class="inner"> Main </div>*
  </div> 
  <div class="left">Left</div> 
  <div class="right">Right </div>
</div>
<div class="footer">Footer</div>

样式:

去掉了左右栏的相对定位

去掉包裹层padding,以中间栏新增div的margin代替

body{
          padding:0;
          margin:0
        }
        .header,.footer{
          width:100%;  
          background:#666;
          height:30px;clear:both;
        }
        .bd{
            
            
        }
        .left{
            background: #E79F6D;
            width:150px;
            float:left;
            margin-left:-100%;
            
            
        }
        .main{
            background: #D6D6D6;
            width:100%;
            float:left;
        }
        .right{
            background: #77BBDD;
            width:190px;
            float:left;
            margin-left:-190px;
            
            
        }
        .inner{
            margin-left:150px;
            margin-right:190px;
        }

3、双飞翼布局和圣杯布局的区别

圣杯布局和双飞翼布局解决问题的方案在前一半是相同的,即:

  • 中间栏宽度设置为100%

  • 三栏全部float浮动

  • 左右两栏加上负margin让其跟中间栏div并排,以形成三栏布局。

不同在于解决中间栏div内容不被遮挡问题的思路不一样。

圣杯布局

  • 将三栏的外包裹层设置左右padding-left和padding-right

  • 将左右两个div用相对布局position: relative并分别配合right和left属性,相对自身移动以便不遮挡中间div

双飞翼布局

  • 中间div内部创建子div用于放置内容

  • 在该子div里用margin-left和margin-right为左右两栏div留出位置

多了1个div,少用4个css属性(圣杯布局中间divp的adding-left和padding-right这2个属性,加上左右两个div用相对布局position: relative及对应的right和left共4个属性,一共6个;而双飞翼布局子div里用margin-left和margin-right共2个属性,6-2=4)。

并且双飞翼布局还有个好处,让Main变成BFC元素了,屏幕宽度缩小Main也不会被挤下去,圣杯布局就会被挤下去。

以上是“css中双飞翼布局和圣杯布局的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网node.js频道!

--结束END--

本文标题: css中双飞翼布局和圣杯布局的示例分析

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

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

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

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

下载Word文档
猜你喜欢
  • css中双飞翼布局和圣杯布局的示例分析
    这篇文章主要为大家展示了“css中双飞翼布局和圣杯布局的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css中双飞翼布局和圣杯布局的示例分析”这篇文章吧...
    99+
    2024-04-02
  • 如何实现CSS布局中的圣杯布局与双飞翼布局
    这篇文章将为大家详细讲解有关如何实现CSS布局中的圣杯布局与双飞翼布局 ,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。按照我的理解,其实圣杯布局跟双飞翼布局...
    99+
    2024-04-02
  • JavaScript圣杯布局与双飞翼布局实现案例详解
    目录一、圣杯布局和双飞翼布局的功能介绍二、圣杯布局高度如何自适应屏幕高度圣杯布局思路圣杯布局代码三、双飞翼布局双飞翼布局的思路双飞翼布局的代码圣杯布局和双飞翼布局的区别四、圣杯布局和...
    99+
    2022-11-13
    JavaScript 圣杯布局 JavaScript 双飞翼布局
  • CSS布局教程:实现双飞翼布局的最佳方法
    CSS布局是网页设计中非常关键的一部分,它决定了网页的外观和结构。双飞翼布局是一种常见的CSS布局方式,它可以实现左右两侧固定宽度的列和中间自适应宽度的主体内容。本文将介绍实现双飞翼布局的最佳方法,并提供具体的代码示例。首先,我们需要一个H...
    99+
    2023-10-21
    最佳方法 CSS布局 双飞翼布局
  • 使用CSS怎么实现双飞翼布局
    使用CSS怎么实现双飞翼布局?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。方式一:通过flex弹性布局来实现看代码//HTML结构,div2是中间的自适应区域...<bo...
    99+
    2023-06-08
  • CSS布局教程:实现圣杯布局的最佳方法
    引言:在网页开发中,布局是非常重要的一部分。好的布局能够使网页达到更好的可读性和可访问性。其中,圣杯布局是一种非常经典的布局方式,它能够在实现自适应的情况下使内容居中,保持优雅的显示效果。本文将为大家介绍如何使用最佳的方法实现圣杯布局,并给...
    99+
    2023-10-21
    最佳方法 CSS布局 圣杯布局
  • CSS中Gird布局的示例分析
    这篇文章主要介绍CSS中Gird布局的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!CSS网格布局是一个二维的基于网格的布局系统, 其目的在于完全改变我们设计基于网络的用户界...
    99+
    2024-04-02
  • CSS中圣杯布局的三列式怎么用
    这篇文章给大家介绍CSS的三列式怎么用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。DOM结构如下:XML/HTML Code复制内容到剪贴板<di...
    99+
    2024-04-02
  • css中sticker-footer布局的示例分析
    这篇文章将为大家详细讲解有关css中sticker-footer布局的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在网页设计中,Sticky footers设计...
    99+
    2024-04-02
  • CSS布局方案的示例分析
    这篇文章给大家分享的是有关CSS布局方案的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。居中布局水平居中1)使用inline-block+text-align原理:先将子...
    99+
    2024-04-02
  • Flex布局和Grid布局实例分析
    本文小编为大家详细介绍“Flex布局和Grid布局实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“Flex布局和Grid布局实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新...
    99+
    2024-04-02
  • css中flex弹性布局的示例分析
    这篇文章将为大家详细讲解有关css中flex弹性布局的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。案例基础布局html<ul class="box">&...
    99+
    2023-06-08
  • CSS中Grid网格布局的示例分析
    这篇文章主要介绍CSS中Grid网格布局的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!介绍CSS Grid(网格) 布局使我们能够比以往任何时候都可以更灵活构建和控制自定义...
    99+
    2024-04-02
  • CSS中flex布局实例分析
    这篇文章主要介绍“CSS中flex布局实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“CSS中flex布局实例分析”文章能帮助大家解决问题。1. 浏览器 fl...
    99+
    2024-04-02
  • HTML布局的示例分析
    这篇文章主要介绍HTML布局的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 网站常常以多列显示内容(就像杂志和报纸)。 使用 <div> 元素的 HTML ...
    99+
    2024-04-02
  • Flex布局的示例分析
    小编给大家分享一下Flex布局的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Flex布局基础一,Absolute布局用Flex布局新建Applicati...
    99+
    2023-06-17
  • css Flexbox布局实例分析
    今天小编给大家分享一下css Flexbox布局实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。概念Flexbox是f...
    99+
    2023-06-30
  • Dreamweaver CS3中布局的示例分析
    小编给大家分享一下Dreamweaver CS3中布局的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、CSS规则定义之“类型”类型主要针对文本属性进行...
    99+
    2023-06-08
  • css布局之BFC模式的示例分析
    这篇文章主要为大家展示了“css布局之BFC模式的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css布局之BFC模式的示例分析”这篇文章吧。详解BFC...
    99+
    2024-04-02
  • web开发中响应式布局和自适应布局的示例分析
    这篇文章给大家分享的是有关web开发中响应式布局和自适应布局的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。   1. 设置 Meta 标签   大多数移动浏览器将H...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作