圣杯布局的原理

圣杯布局的原理圣杯布局的起源InSearchoftheHolyGrail圣杯布局解决的问题两边定宽,中间自适应的三栏布局,中间栏要放在文档流前面以优先渲染。圣杯布局的原理HTML代码<divclass="content"><divclass="centercol"></div><divclass="leftcol"></div>

大家好,又见面了,我是你们的朋友全栈君。

圣杯布局的起源

In Search of the Holy Grail

圣杯布局解决的问题

两边定宽,中间自适应的三栏布局,中间栏要放在文档流前面以优先渲染。

圣杯布局的原理

HTML代码

<div class="content">
    <div class="center col">
    </div>
    <div class="left col">
    </div>
    <div class="right col">
    </div>
</div>

CSS代码

第一步:定义容器content的样式padding: 0 100px,以及center,left,right的公共样式,同时定义每个容器的颜色和宽度,左右固定一百,中间100%;

.content{ 
   padding: 0 100px;}
.col{ float: left; height: 200px; position: relative; }
.left,.right{ width: 100px; }
.left{ background-color: blue; }
.right{ background-color: green; }
.center{ width: 100%; background-color: pink; }

效果图:
基础样式效果图

第二步:采用负边距将left和right放到左右两边
1. 当左右设置不同方向负边距margin-left和margin-right

.left{ 
   margin-left:-100%;}
.right{ 
   margin-right:-100px;}
  1. 当左右设置同方向负边距margin-left
.left{ 
   margin-left:-100%;}
.right{ 
   margin-left:-100px;}

效果图:
采用负边距定位效果图

此时我们可以清晰的看到center的左右两边都被left和center遮挡,此时圣杯布局如何处理呢?
第三步:用相对定位来解决
1. 当左右设置不同方向负边距margin-left和margin-right

.left{ 
   right:100px;}
  1. 当左右设置同方向负边距margin-left
.left{ 
   right:100px;}
.right{ 
   left:100px;}

最终效果和CSS代码

效果图:
相对定位后的效果图
1. 当左右设置不同方向负边距margin-left和margin-right

.content{ 
   padding: 0 100px;}
.col{ float: left; height: 200px; position: relative; }
.left,.right{ width: 100px; }
.left{ background-color: blue; margin-left: -100%; right: 100px; }
.right{ background-color: green; margin-right: -100px; }
.center{ width: 100%; background-color: pink; }
  1. 当左右设置同方向负边距margin-left
.content{ 
   padding: 0 100px;}
.col{ float: left; height: 200px; position: relative; }
.left,.right{ width: 100px; }
.left{ background-color: blue; margin-left: -100%; right: 100px; }
.right{ background-color: green; margin-left: -100px; left:100px; }
.center{ width: 100%; background-color: pink; }

优点:

  • 兼容所有浏览器
  • 不用JS计算中间容器宽度就能自适应

缺点:

  • 采用了相对定位,既然用了相对定位(position:relative;),何不使用绝对定位(position:absolute;),更加简单、直接、易懂!

其他

我的博客,欢迎交流!

我的CSDN博客,欢迎交流!

微信小程序专栏

前端笔记专栏

微信小程序实现部分高德地图功能的DEMO下载

微信小程序实现MUI的部分效果的DEMO下载

微信小程序实现MUI的GIT项目地址

微信小程序实例列表

前端笔记列表

游戏列表

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148520.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Unity3D开发资料

    Unity3D开发资料分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;前言(一定要看)首先说

    2022年7月16日
    17
  • git学习——设置gitlab、github默认push的用户名和密码

    在使用git的时候,不同的环境下,当你重新安装git,最好在开始的时候就配置一下默认的git的用户名和密码,这样子就可以在每次的push的时候不需要手动的在去输入git的用户名和密码,提高执行的效率。 环境:Windows环境已经安装git,我使用的gitlab(github和这样配一样),gitlab的用户名742981086@qq.com 下面在Windows环境中进行配置过程的演示, 1

    2022年2月25日
    324
  • WPF教程2013新版「建议收藏」

    视频目录:(一)WPF基础:控件模型、XAML基础、基础控件【.Net培训—第三季WPF教程】001-课程说明【.Net培训—第三季WPF教程】002-VisualStudio下WPF开发环境的基本使用.zip【.Net培训—第三季WPF教程】003-sender是什么.zip【.Net培训—第三季WPF教程】004-复习继承和类型转换.zip【.Net培训—第三季WPF教程】005-集…

    2022年4月9日
    46
  • 带你深入了解 GitLab CI/CD 原理及流程

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 作者:狂乱的贵公子 cnblogs.com/cjsblog/p/12256843.html GitLab CI/CD…

    2021年6月25日
    78
  • javascript 幻灯片代码(含自动播放)「建议收藏」

    javascript 幻灯片代码(含自动播放)「建议收藏」HTMLcssJS

    2022年7月4日
    26
  • DHCP协议 详解[通俗易懂]

    DHCP协议 详解[通俗易懂]原文地址:http://blog.csdn.net/windeal3203/article/details/50677166  DHCP:动态主机配置协议  TCP/IP协议想要运行正常的话,网络中的主机和路由器不可避免地需要配置一些信息(如接口的IP地址等)。有了这些配置信息主机/路由器才能提供/使用特定的网络服务。  主机信息的必要元素有:IP地址、子网掩码、DNS服务器IP地址

    2022年5月24日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号