web前端进阶_css布局_基础篇3

web前端css布局

一、标准流布局

1.标准流布局

标签在没有布局相关的属性的时候,默认的布局方式就是标准流布局。

标准流布局相关标签属性/特点举例
a.块级标签一个占一行;默认宽度是父标签的宽度,默认高度是内容的高度;设置宽高有效h1~h6、p、div、列表相关…
b.行内标签一行可以显示多个;默认大小是内容的大小;设置宽高度无效。a、span、label、font…
c.行内块标签一行可以显示多个;默认大小是内容的大小;设置宽高有效。img、输入框

2.display属性(css)

属性名称主要功能
block将标签修改成块级标签
inline将标签修改成行内标签
inline-block将标签修改成行内块
none隐藏标签

相关展示代码如下:

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8">
  <title></title>
 </head>
 <body>
        <h1>1.块级标签</h1>
        <h1 style="background-color: hotpink; width: 200px;">我是标题1</h1>
        <h2 style="background-color: salmon; width: 120px;">我是标题2</h2>
        <p style="background-color: skyblue;">我是段落1</p>
        <p>我是段落2</p>
        <div style="background-color: yellowgreen; height: 60px;">
            我是div1
        </div>
        <div id="">
            我是div2
        </div>
        
        <h1>2.行内标签</h1>
        <a href="" style="background-color: aquamarine; width: 300px; height: 100px;">我是超链接1</a>
        <a href="" style="background-color: sandybrown;">超链接2</a>
        <label style="background-color: skyblue; height: 60px;">我是lable1</label>
        <label>我是lable1</label>
        
        <h1>3.行内块标签</h1>
        <img style="background-color: sandybrown; width: 400px;" src="img/anchor.png" >
        <img src="img/ghost.png" >
        <input type="text" name="" id="" value="" />
        <input style="height: 60px;" type="text" name="" id="" value="" />
        
        <h1>display属性</h1>
        <div style="background-color: sandybrown; width: 200px; display: inline;">
            div3
        </div>
        <div style="background-color: skyblue; height: 100px; display: inline;">
            div4
        </div>
        
        <a style="width: 100px; height: 100px; background-color: deeppink; display: inline-block;">超链接3</a>
        <a style="background-color: salmon; display: block;">超链接4</a>
        <img style="display: none;" src="img/hat.png" >
        
 </body>
</html>

显示效果:
在这里插入图片描述

二、标准流网页布局

使用inline-block(行内块标签)进行布局时存在以下问题:

  1. 将两块区域内容放在同一行,中间会存在空隙
  2. 如果将两块的区域宽度加起来为100%,不能显示在一行,会出现换行,所以此种方式不太适合实现此种功能,如要实现此种功能,需要使用后面讲到的浮动功能
    第一种方式:width的和为100%(没显示在一行)
<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8">
  <title></title>
 </head>
 <body>
        <div style="height: 120px; background-color: sandybrown;"></div>
        <div style="width: 40%; height: 600px; background-color: skyblue; display: inline-block;"></div>
        <div style="width: 60%; height: 600px; background-color: pink; display: inline-block;"></div>
 </body>
</html>

在这里插入图片描述
第二种方式:width和小于100%(存在空隙)
在这里插入图片描述

三、浮动

1.脱流
让标签脱离标准流,不再按照标准流的方式进行布局。浮动和定位都可以让标签脱流。
所有的标签,只要脱离了标准流,布局的方式就只有一种:一行显示多个;默认大小是内容的大小;设置宽高有效

2.浮动 - float

浮动属性作用
left左浮动
right右浮动
<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8">
  <title></title>
 </head>
 <body>
        <h1>浮动可以脱流</h1>
        <div style="background-color: salmon; height: 100px; float: left;">
            div1
        </div>
        <div style="float: left; background-color: aquamarine;">
            div2
        </div>
        <a href="" style="background-color: pink; width: 100px; height: 100px; float: left;">我是超链接1</a>
        <a href="" style="background-color: azure;">我是超链接2</a>
        
        <h1>页面整体布局</h1>
        <div style="background-color: sandybrown; height: 120px; width: 100%; float: right;"></div>
        <div style="background-color: chartreuse; width: 40%; height: 600px; float: right;"></div>
        <div style="background-color: blueviolet; width: 60%; height: 600px; float: right;"></div>
        
        
 </body>
</html>

在这里插入图片描述

四、浮动原理

如果块标签不浮动,占水面和池底的空间,并且还带着玻璃砖。
浮动的标签,只占水面的空间

(注意:如果前面先添加浮动标签内容,后面如果来了块标签,块标签可能会和浮动标签产生重合区域)

五、浮动的应用

1.竖着显示的横着来(页面布局)
2.文字环绕: 被环绕的块浮动,文字块不浮动
展示代码如下所示:

<!DOCTYPE html>
<html>
<head>
 <meta charset="utf-8">
 <title></title>
</head>
<body>
       <div style="float: left;">
           <img src="img/bucket.png" >   #图片浮动
       </div>
       <div style="width: 220px;">        #div标签中的内容不浮动
           asdhfkajshdfk 阿斯蒂芬卡萨丁加法和
           阿斯顿发数据库东方航空
           阿萨德发客户萨科技发的
           熬枯受淡房间卡是
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
           <a href="">超链接1</a>
       </div>
</body>
</html>

web显示效果如下所示:
在这里插入图片描述

六、清除浮动

清除浮动的原因:
清除因为浮动而产生的高度塌陷的问题

1)高度塌陷: 父标签不浮动并且没有设置高度,子标签浮动就可能产生高度塌陷(没有设置高度的父标签会塌陷)
2)清除浮动:

清除浮动的方法具体操作方式
a.空盒子法在高度会塌陷的标签的最后添加一个空的div,并且设置它的clear属性为both,<div style=“clear: both;”></div>
b.设置overflow设置高度会塌陷的标签的overflow属性为hidden
<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8">
  <title></title>
 </head>
 <body>
        <div style="height: 120px; background-color: pink;"></div>
        <div class="subside" style="background-color: greenyellow;">
            <div style="background-color: red; height: 100px; width: 100px;">
                
            </div>
            <div style="background-color: saddlebrown; height: 400px; width: 35%; float: left;"></div>
            <div style="background-color: skyblue; height: 1300px; width: 40%; float: right;"></div>
            
            <!-- 1.空盒子法 -->
            <!-- <div style="clear: both;"></div> -->
        </div>
        <div style="height: 80px; background-color: seagreen;"></div>
        
        <!-- 2.设置overflow -->
        <style type="text/css">
            .subside{
                overflow: hidden;
            }
        </style>
        
 </body>
</html>

在这里插入图片描述

七、定位

1.定位

定位的属性有四个:left、right、top、bottom

定位属性对应功能
left设置标签的左边到另外一个标签的左边距离
right设置标签的右边到另外一个标签的右边的距离
top设置标签顶部到另外一个标签的顶部的距离
bottom设置标签的底部到另外一个标签底部的距离

2.选择定位的参考对象:position

position可选择的属性对应功能
static/initial(默认值,body例外)不选参考对象,不定位(设置距离直接无效)
absolute(绝对定位)选择第一个非static/initial的父标签作为参考对象
relative(相对定位)相对当前标签在标准流中的位置定位(一般用于让自己成为子标签的参考对象的时候用)
fixed相对浏览器定位
sticky可以实现显示在最下面的一行内容,当其他内容在一页中显示不了时,当滑动右边网页时,其一直显示在最下方;如果其他内容很少,最下面一行也可以往网页上面的位置挪

举例展示代码:

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8">
  <title></title>
 </head>
 <body>
        <!-- <h1>1.直接设置定位的距离无效</h1>
        <style type="text/css">
            #div1{
                left: 300px;
                position: static;
            }
        </style>
        <div id="div1" style="background-color: red; width: 100px; height: 100px;"></div>
        
        <h1>2.绝对定位</h1>
        <div id="div2" style="background-color: green; width: 300px; height: 300px;">
            <div id="div3" style="background-color: yellow; width: 200px; height: 200px;">
                <div id="div4" style="background-color: blue; width: 100px; height: 100px;">
                    
                </div>
            </div>
        </div>
        <style type="text/css">
            #div2{
                /* 设置position是为了成为参考对象 */
                position: relative;
            }
            #div4{
                top: 10px;
                right: 50px;
                /* 设置position是为了能够让自己相对别人去定位(选定位的参考对象) */
                position: absolute;
            }
        </style> -->
        
        <!-- <h1>3.相对定位</h1>
        <div id="div5" style="background-color: red; width: 200px; height: 200px;"></div>
        <style type="text/css">
            #div5{
                bottom: 50px;
                /* 如果设置position为relative是把自己原来的位置作为参考对象,很少使用;一般设置
                 positio为relative是为了让自己成为别人的参考对象*/
                position: relative;
            }
        </style> -->
        
        <!-- <h1 id="top">相对浏览器定位</h1>
        <div style="height: 10000px;">
            <div id="div6" style="background-color: red; width: 100px; height: 50px;">
                <a href="#top">回到顶部</a>
            </div>
        </div>
        <p>我是底部</p>
        <style type="text/css">
            #div6{
                right: 40px;
                bottom: 30px;
                position: fixed;
            }
            
        </style> -->
        
        <h1>sticky</h1>
        <div id="" style="background-color: red; height: 2000px;">
            
        </div>
        <div id="div7" style="background-color: green; height: 100px;">
            
        </div>
        <style type="text/css">
            #div7{
                bottom: 0px;
                position: sticky;
            }
        </style>
        
        
 </body>
</html>

八、盒子模型

1.盒子模型

html中每一个可见的标签不管在任何情况下都是由4个部分组成:content、padding、border和margin

标签组成元素属性和功能
content可见的;设置背景会作用于content;设置标签的宽度和高度其实就是在设置conten的宽度和高度;标签内容和子标签都是添加到content上的
padding可见的;设置背景会作用于padding;padding有四个方向,每个方向可以单独控制
border可见的;border有四个方向,每个方向也可以单独控制
margin不可见但是占位置;有四个方向,每个方向也可以单独控制

代码举例展示:

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8">
  <title></title>
 </head>
 <body >
        
        <div id="div1" style=" background-color: greenyellow;"><img src="img/aaa.ico" >div1</div>
        <input type="text" style="padding-left: 10px;"/>
        
        <style type="text/css">
            #div1{
                /* 1.content */
                width: 100px; 
                height: 100px;
                
                /* 2.padding (可以让标签内容和标签的边框在某个方向上保持一个的距离)
                   1)同时设置4个方向的padding:paddidng:大小;
                   2)单独设置指定方向的padding: padding-left、padding-right、padding-top、padding-bottom
                */
               padding: 20px;
               
               /* 3.border
                  1)同时设置4个方向的border:
                  border:边框大小 边框样式 边框颜色;  (边框样式:solid-实线、dotted-点划线、dashed-虚线、double-双实线)
                  2)单独设置指定方向的border
                  border-left、border-right、border-top、border-bottom
                */
               /* border: 5px solid red; */
               border-left: 3px solid red;
               border-top: 5px dotted purple;
               border-bottom: 4px dashed seagreen;
               border-right: 3px double blue;
                
               /* 4.margin */
               /* margin: 100px; */
               margin-left: 50px;
            }
            
            
        </style>
        
            
        </div>
 </body>
</html>

web显示结果:
在这里插入图片描述

九、简单训练

实现功能如下:
在网页一块固定区域内显示多个相同的方框,整齐排列,当网页缩小或者变大,方框的排列也会跟着变化

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8">
  <title></title>
 </head>
 <body>
        <div style="background-color: yellow; width: 50%; overflow: hidden; margin-top: 100px; margin-left: 200px; padding-bottom: 30px;">
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>  
            <div></div>
            <div></div>
            <div></div>
        </div>
       
        
        <style type="text/css">
            div>div{
                width: 100px;
                height: 100px;
                background-color: red;
                
                margin-left: 20px;
                margin-top: 20px;
                float: left;
            }
        </style>
 </body>
</html>

代码输出的效果图如下所示:
网页显示区域没有缩小时的显示效果:
在这里插入图片描述
网页缩小后的显示效果,方框自动变化:在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值