iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > html >CSS中怎么固定宽度布局
  • 519
分享到

CSS中怎么固定宽度布局

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

这篇文章主要介绍“CSS中怎么固定宽度布局”,在日常操作中,相信很多人在CSS中怎么固定宽度布局问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS中怎么固定宽度布局”的疑惑

这篇文章主要介绍“CSS中怎么固定宽度布局”,在日常操作中,相信很多人在CSS中怎么固定宽度布局问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS中怎么固定宽度布局”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

.布局前的认知
1.1 三种基本方案

多栏布局有三种基本的实现方案:固定宽度、流动、弹性。

    固定宽度。布局的大小不会随用户调整浏览器窗口大小而变化,一般是 900 到 1100 像素宽(最常见的是 960 像素)。

    流动。布局的大小会随用户调整浏览器窗口大小而变化。(结合 CSS 媒体查询,能够适应最大和最小的屏幕,业界称之为 响应式设计。)

    弹性。在浏览器窗口变宽时,不仅布局变宽,而且所有内容元素的大小也会变化。(实现太过复杂,不多介绍。)

1.2 布局高度

多数情况下,布局中结构化元素(乃至任何元素)的高度是 不必或者不应该设定的。因为保持元素 height 属性的默认值 auto 不变,才能使元素根据自己包含内容的增加而在垂直方向上扩展。这样扩展的元素会把下方的元素向下推,而布局也能随内容数量的增减而垂直伸缩。
1.3 布局宽度

为了使浏览器窗口宽度合理变化,布局能作出适当的调整,我们 需要精细地控制 布局宽度。
2.三栏-固定宽度布局

结构如下:
CSS中怎么固定宽度布局

上代码:

XML/html Code复制内容到剪贴板

  1. <!DOCTYPE html>   

  2. <html lang="en">   

  3. <head>   

  4.     <meta charset="UTF-8">   

  5.     <title>三栏-固定宽度布局</title>   

  6.     <style>   

  7.         * {   

  8.             margin: 0;    

  9.             padding: 0;   

  10.         }   

  11.         #wrapper{   

  12.             width: 960px;   

  13.             margin: 0 auto;   

  14.             border:1px solid;   

  15.         }   

  16.         header{   

  17.             background: #f00;   

  18.         }   

  19.         nav{   

  20.             background: #dcd9c0;   

  21.             width: 150px;   

  22.             float:left;   

  23.         }   

  24.         article{   

  25.             background: #ffed53;   

  26.             width: 600px;   

  27.             float: left;   

  28.         }   

  29.         aside{   

  30.             background: #6a6b6c;   

  31.             width: 210px;   

  32.             float: left;   

  33.         }   

  34.         footer{   

  35.             clear:both;                

  36.             background: #6a6b6c;   

  37.         }   

  38.     </style>   

  39. </head>   

  40. <body>   

  41.     <div id="wrapper">   

  42.         <header>   

  43.             This is header.   

  44.         </header>   

  45.         <nav>   

  46.             This is nav<br>   

  47.             This is nav<br>   

  48.             This is nav<br>   

  49.         </nav>   

  50.         <article>   

  51.             This is article.<br>   

  52.             This is article.<br>   

  53.             This is article.<br>   

  54.             This is article.<br>   

  55.             This is article.<br>   

  56.             This is article.<br>   

  57.             This is article.<br>   

  58.             This is article.<br>   

  59.             This is article.<br>   

  60.         </article>   

  61.         <aside>   

  62.             This is aside.   

  63.         </aside>   

  64.         <footer>   

  65.             This is footer.   

  66.         </footer>   

  67.     </div>   

  68. </body>   

  69. </html>  

结果如图:
CSS中怎么固定宽度布局

说明几点:

    通过给整个外包装(#wrapper)设定宽度值(960px),并将其水平外边距设定为 auto,就能实现居中。随着向里面添加内容,相关的栏的高度会增加。

    设置宽度并浮动中间三栏(nav、article 和 aside),让它们并排显示。使用属性:width 和 float。

    三栏的总宽度加起来要等于外包装的宽度(150 + 600 + 210 = 960)。同样使用该方法就可以加任意多栏,只要它们的总宽度等于外包装的宽度即可。

    页脚(footer)位于浮动元素后面,所以就会尽量往上移动。解决这个问题的方法就是使用 清除浮动(clear:both;或者使用clear:left;也可以,因为这里只有左浮动元素)。

3.为栏设定内边距和边框

在上面的布局中,只要一调整各栏中的内容,布局就可能超过容器宽度,而右边的栏就可能滑到左边的栏下方。例如为了让内容与栏边界空开距离,为栏添加水平外边距和内边距,或者为了增加爱栏间距,为栏添加外边距,导致布局宽度增大,进而浮动栏下滑;又或者在栏中添加大图片,或者没有空格的长字符串(如长URL),也会导致栏宽大超过布局宽度。

示例:

CSS Code复制内容到剪贴板

  1. article{   

  2.     background: #ffed53;   

  3.     width: 600px;   

  4.     float: left;   

  5.     padding: 10px 20px;      

  6. }  

结果就会变成这样:
CSS中怎么固定宽度布局

我们把这种现象称为 浮动滑移,可以使用三种方法来预防发生:

    从设定的元素宽度中减去添加的水平外边距、边框和内边距的宽度和。
    在容器内部的元素上添加内边距或外边距。
    使用 css3 的 box-sizing 属性切换盒子缩放方式。应该该属性后,给元素添加边框和内边距都不会增大盒子,相反会导致内容变窄。

下面来讨论这三种方法:
3.1 重设宽度以抵消内边距和边框

由于上面给 article 栏添加了左右 20px 的水平边距,故将该栏宽度从 600px 减至 560px,故修改后的 article 栏 css 样式规则如下:

CSS Code复制内容到剪贴板

  1. article{   

  2.     background: #ffed53;   

  3.     width: 560px;      

  4.     float: left;   

  5.     padding: 10px 20px;     

  6. }  

效果如下:
CSS中怎么固定宽度布局

虽然能实现,但每次只要调整内、外边距就要重设布局宽度,非常烦人,而且还可能导致页面错乱。
3.2 给容器内部的元素应用内边距和边框

把外边距和内边距应用到内容元素上确实有效,前提是这些元素没有明确地设定宽度,这样它们的内容才会随着内、外边距的增加而缩小。

    根据盒模型定义,没有宽度的元素在水平方向上会适应其父元素,其内容会随着外边距、边框和内边距的增加而减少。

考虑到将来修改的时候,一栏中可能包含大量不同内容的元素,如果想重新调整内容与容器边界的距离,就必须每个元素都要进行调整,这样不仅麻烦,而且容易出错。况且,给栏添加边框同样会增大栏宽,不可能通过为其包含的内容元素逐个添加应用样式来做到。

所以说,与其为容器中的元素添加外边距,不如 在栏中再添加一个没有宽度的 div,让它包含所有内容元素,然后再给这个 div 应用边框和内边距。如此一来,只要为内部 div 设定一次样式,就可以把让所有内容元素与栏边界保持一致的距离。而且,将来再需要调整时也会很方便。任何新增内容元素的宽度都由这个内部 div 决定。

还是拿 article 栏来开刀:

XML/HTML Code复制内容到剪贴板

  1. <article>   

  2.     <div class="inner">    <!-- 添加一个div -->   

  3.         This is article.<br>   

  4.         This is article.<br>   

  5.         This is article.<br>   

  6.         This is article.<br>   

  7.         This is article.<br>   

  8.         This is article.<br>   

  9.         This is article.<br>   

  10.         This is article.<br>   

  11.         This is article.<br>   

  12.     </div>   

  13. </article>  

增改样式如下:

CSS Code复制内容到剪贴板

  1. article{   

  2.     background: #ffed53;   

  3.     width: 600px;   

  4.     float: left;   

  5. }    

  6. article .inner{   

  7.     margin: 10px;   

  8.     border:2px solid red;   

  9.     padding: 20px;   

  10. }     

效果如下:
CSS中怎么固定宽度布局

从结果可以看出,中间栏的宽度并未因此有多少变化,因为内容区减少的宽度抵消了应用到内部 div 上的外边距、边框和内边距的总宽度。于是,我们可以这样结论:如果布局中的栏是浮动的,而且都设定了宽度,你就不要去动它!要动,就把内容放在内部 div 里,动这个 div。
3.3 使用 box-sizing:border-box

这是最简单的一个方法。只要在三个浮动的栏的 CSS 规则中分别 加上 box-sizing:border-box 声明,再给栏添加内边距(和边框)就不会导致盒子的宽度变化。此时,既不用调整栏宽去抵消增加的内边距,也不用使用内部 div。添加内边距的结果就是内容收缩。

示例:

以下是简介清晰的没有内部 div 的标记:

XML/HTML Code复制内容到剪贴板

  1. <div id="wrapper">  

  2.     <header>  

  3.         <!-- 标题 -->  

  4.     </header>  

  5.     <nav>  

  6.         <ul>  

  7.             <!-- 链接 -->  

  8.         </ul>  

  9.     </nav>  

  10.     <article>  

  11.         <!-- 文本 -->  

  12.     </article>  

  13.     <aside>  

  14.         <!-- 文本 -->  

  15.     </aside>  

  16.     <footer>  

  17.         <!-- 文本 -->  

  18.     </footer>  

  19. </div>  

相应的,CSS 规则如下:

CSS Code复制内容到剪贴板

  1. * {    

  2.     margin: 0;    

  3.     padding: 0;   

  4. }   

  5. #wrapper{   

  6.     width: 960px;   

  7.     margin: 0 auto;   

  8.     border:1px solid;   

  9. }   

  10. header{   

  11.     background: #f00;   

  12. }   

  13. nav{   

  14.     box-sizing:border-box;      

  15.     background: #dcd9c0;   

  16.     width: 150px;   

  17.     float:left;   

  18.     padding: 10px 20px;         

  19. }   

  20. article{   

  21.     box-sizing:border-box;      

  22.     background: #ffed53;   

  23.     width: 600px;   

  24.     float: left;   

  25.     padding: 10px 20px;         

  26. }   

  27. aside{   

  28.     box-sizing:border-box;      

  29.     background: #6a6b6c;   

  30.     width: 210px;   

  31.     float: left;   

  32.     padding: 10px 20px;          

  33. }   

  34. footer{   

  35.     clear:both;             

  36.     background: #6a6b6c;   

  37. }  

结果如下:

box-sizing:border-box 确实起作用了。
CSS中怎么固定宽度布局

多么好用的一个属性啊!当然也就少不了 但是 &mdash;&mdash; IE6 和 IE7 不支持该属性。

废话少说,解决方案 如下:

使用一个专门解决这个问题的腻子脚本(polyfill),名叫 borderBoxModel.js.
可以使用 条件注释 把它添加到 HTML 标记之后、结束的 </body> 标签之前,以保证在加载 DOM 之后再执行该脚本:

XML/HTML Code复制内容到剪贴板

  1. <body>  

  2. <!-- HTML 标记 -->  

  3. <!-- 只让 IE8 之前的 IE 加载它 -->  

  4. <!-- [if It IE 8] -->  

  5. <script src="helpers/borderBoxModel.js"></script>  

  6. <![endif]-->  

  7. </body>  

到此,关于“CSS中怎么固定宽度布局”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: CSS中怎么固定宽度布局

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

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

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

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

下载Word文档
猜你喜欢
  • CSS中怎么固定宽度布局
    这篇文章主要介绍“CSS中怎么固定宽度布局”,在日常操作中,相信很多人在CSS中怎么固定宽度布局问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS中怎么固定宽度布局”的疑惑...
    99+
    2022-10-19
  • CSS中固定宽度的三列布局怎么用
    这篇文章给大家分享的是有关CSS中固定宽度的三列布局怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。固定宽度三列布局这很基础,我们直接看代码便能明白:<div ...
    99+
    2022-10-19
  • CSS三栏布局中如何进行中间固定宽度两边自适应宽度
    这期内容当中小编将会给大家带来有关CSS三栏布局中如何进行中间固定宽度两边自适应宽度,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 今天早上...
    99+
    2022-10-19
  • CSS实现三列布局两端固定宽度中间自适应
    这篇文章主要讲解了“CSS实现三列布局两端固定宽度中间自适应”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS实现三列布局两端固定宽度中间自适应”吧! ...
    99+
    2022-10-19
  • DIV CSS固定宽度居中的方法
    这篇“DIV CSS固定宽度居中的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“DIV...
    99+
    2022-10-19
  • CSS中怎么将Span标签设置为固定宽度
    这篇文章给大家介绍CSS中怎么将Span标签设置为固定宽度,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 一、形如<span>ABC</...
    99+
    2022-10-19
  • html如何实现宽度固定并布局居中模板框架
    小编给大家分享一下html如何实现宽度固定并布局居中模板框架,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 固定宽度 并居中模...
    99+
    2022-10-19
  • uniapp h5页面怎么固定宽度
    随着移动互联网的快速发展,越来越多的企业开始关注H5应用的开发与部署。而UniApp作为移动端跨平台开发框架的佼佼者,也成为了很多公司和开发者的首选。然而,在开发过程中,可能会遇到一些问题,比如如何固定H5页面的宽度。本文将结合实际案例,介...
    99+
    2023-05-14
  • CSS怎么实现固定宽高比
    这篇文章给大家分享的是有关CSS怎么实现固定宽高比的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、可替换元素实现固定宽高比可替换元素(如 <img> 、 <video> )和其他元素不同...
    99+
    2023-06-08
  • CSS怎么实现独行DIV自适应宽度布局
    这篇文章主要介绍了CSS怎么实现独行DIV自适应宽度布局的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇CSS怎么实现独行DIV自适应宽度布局文章都...
    99+
    2022-10-19
  • html网页宽度固定系统怎么居中
    本篇内容主要讲解“html网页宽度固定系统怎么居中”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“html网页宽度固定系统怎么居中”吧! 对网页主体(网页最外层...
    99+
    2022-10-19
  • 使用css怎么实现两边固定中间自适应布局
    这篇文章将为大家详细讲解有关使用css怎么实现两边固定中间自适应布局,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。浮动<style type="text/css&q...
    99+
    2023-06-08
  • CSS怎么设置宽高等比布局
    本篇内容主要讲解“CSS怎么设置宽高等比布局”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS怎么设置宽高等比布局”吧!宽度是高度的两倍(等比缩放)实现思路: 以父级元素为基准, 子级 wid...
    99+
    2023-07-04
  • css中怎么判断不同分辨率显示不同宽度布局
    本篇文章给大家分享的是有关css中怎么判断不同分辨率显示不同宽度布局,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。使用CSS单词与语法代码如下...
    99+
    2022-10-19
  • 如何实现两侧列固定中间列变宽的Div布局
    这篇文章主要介绍如何实现两侧列固定中间列变宽的Div布局,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!示例<!DOCTYPE html PUBLIC&nbs...
    99+
    2022-10-19
  • CSS边框的宽度怎么指定
    本文小编为大家详细介绍“CSS边框的宽度怎么指定”,内容详细,步骤清晰,细节处理妥当,希望这篇“CSS边框的宽度怎么指定”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。 可以通过...
    99+
    2022-10-19
  • css如何实现元素水平居中显示与固定布局和流式布局
    这篇文章给大家分享的是有关css如何实现元素水平居中显示与固定布局和流式布局的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。首先,要 让元素水平居中,就必须得了解css设计中固定布局和流式布局两者的概念。它们之间的...
    99+
    2023-06-08
  • css 中不定宽高的元素居中布局如何解决
    css 中不定宽高的元素居中布局如何解决?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1. 水平居中公共代码:html:<div class=&...
    99+
    2023-06-08
  • CSS布局中怎么实现绝对定位
    这篇文章给大家介绍CSS布局中怎么实现绝对定位,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、绝对定位绝对定位的优势在于,我们可以丝毫不差地精确控制任何元素的位置—这里面没有什么需要...
    99+
    2022-10-19
  • css怎么固定块级元素的高度
    本篇内容主要讲解“css怎么固定块级元素的高度”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“css怎么固定块级元素的高度”吧!1.首先,在页面中创建一个div标...
    99+
    2022-12-16
    css
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作