2018-10-31 第二阶段 day3-css属性

1.标准流和浮动

1.标准流
标准流布局 :在标准流中,块级标签是一个占一行,默认宽度是父标签的宽度,默认高度是内容的高度并且可以设置宽度和高度
行内标签,一行可以显示多个,默认宽度和高度都是内容的宽度和高度,设置宽高无效
行内块,一行可以显示多个,默认宽度和高度都是内容的宽高,设置宽高有效
块级标签:h1-h6, p, hr,ol/ul/dl/il,table, tr, div
行内标签:a, img, td, input, select, option, textarea,span

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <title></title>
    </head>
    <body>
        <div style="height: 200px; background-color: aqua;"></div>
        <div style="height: 400px; background-color: antiquewhite;">
        
        </div>
        
        <div style="height: 200px; background-color: gray;"></div>
    </body>
</html>

2.display属性

2.display(设置标签的性质)
block-将标签设置为块级标签
inline-block-将标签设置为行内块标签(注意:一般不会通过将标签转换成行内块来解决,因为行内块标签在显示的时候左右中间会有不能消除的空隙)
inline-将标签设置为行内标签

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <title></title>
    </head>
    <body>
        <!-- display:bolck-将a转换成块级标签 -->
        <a href="", style="display: block; background-color: aqua; width: 200px;">abc</a>
        <!-- display:inline-block-将a转换成行内块标签 -->
        <a href="", style="display: inline-block; background-color: green; width: 200px;">123</a>
        <a href="", style="display: inile; background-color: aqua; width: 200px;">abc</a>
    </body>
</html>

3.float属性

1.浮动的原理
a.浮动会让标签脱离标准流进行布局(脱流)
b.没有浮动的标签既占池底的位置,也占水面的位置,浮动后只占水面的位置

2.float属性
lef-左浮动
right-右浮动
3.脱流后的布局规则:不管什么标签,脱流后都是一行可以显示多个,可以设置宽度和高度

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style type="text/css">
            p{
                background-color: chartreuse;
                float: left;
                width: 200px;
            }
            a{
                background-color: sandybrown;
                width: 200px;
                float: left;
            }
            
            div{
                width: 200px;
            }
        </style>
    </head>
    <body>
        <!--1.设置float属性后会脱流-->
        <!-- <p>我是段落1</p>
        <p style="background-color: yellow;">我是段落2</p>
        <a href="">aaa</a>
        <a href="">bbb</a> -->
        <div style="background-color: hotpink; height: 300px;float: right;">div1</div>
        <div style="background-color: goldenrod; height: 200px;">
            div2
        </div>
        <div style="background-color: yellow; height: 400px; ">div3</div>
        <a href="">aaa</a>
        
        
    </body>
</html>

4.清除浮动

1.清除浮动
清除浮动指的是清除因为浮动而产生的高度塌陷问题

2.高度塌陷
当父标签不浮动,并且不设置高度;但是子标签浮动的时候就会产生高度塌陷问题

3.清除浮动的方法:
a.添加空的div: 在父标签的最后添加一个空的div,并且设置样式clear属性的值为both
b.在会塌陷的标签中添加样式,将overflow属性的值设置为hidden
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style type="text/css">
            /*方案2*/
            #div2{
                overflow: hidden;
            }
        </style>
    </head>
    <body>
        <div style="background-color: hotpink; height: 100px;"></div>
        
        <!--div2会出现高度塌陷问题-->
        <div id="div2" style="background-color: yellow;">
            <div style="background-color: peru; height: 100px; width: 200px;float: left;"></div>
            <div style="background-color: seagreen; height: 200px;width: 200px; float: right;"></div>
            
            <!--方案1-->
            <!--<div style="clear: both;"></div>-->
        </div>
        <div style="background-color: lightblue; height: 120px;"></div>
        
    </body>
</html>

5.文字环绕效果

文字环绕:被环绕的标签(例如图片对应的标签)浮动;文字对应的标签不浮动

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>
    <body>
        <!--图片对应块-->
        <div id="" style="background-color: sandybrown; float: left;">
            <img src="img/.png"/>
        </div>
        
        <!--文字对应的块-->
        <div id="" style="background-color: yellow;">

        文字部分
        
    </body>
</html>

6.定位

css可以通过letf,right,top,bottom来对标签进行定位 ,前提是设置好参考对象
1.定位的属性:
left-标签左边距
right-标签右边距
top-标签上边距
bottom-标签上边距

注意:a.定位需要通过position属性来设置参考对象
b.当标签的宽度固定的时候,同时设置left和right只有left有效(top和bottom同理)
c.可以同时设置left和right,不设置宽度或者宽度值为auto的时候,标签会自动拉伸
2.position属性
initial(默认值)
static-不希望自己的子标签相对自己定位的时候才使用static()
absolute-相对第一个非static和非initial的父标签进行定位
relative-相对于自己在标准流中的位置定位,如果一个标签希望自己的子标签能够相对自己定位就设置这个标签的position为relative自己不定位
fixed-相当于浏览器定位
sticky-粘性定位,值针对网页底部的标签定位,如果网页内容超过一屏(需要滚动)的时候,相对浏览器定位否则相对标准流定位

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        
        <style type="text/css">
            #div1{
                width: 600px;
                height: 400px;
                background-color: hotpink;
                
            }
            #div2{
                width: 400px;
                height: 300px;
                background-color: navajowhite;
                
                
                position: relative;
                
                /*裁掉自己的子标签超出自己的范围的部分*/
                overflow: hidden;
            }
            #div3{
                
                background-color: green;
                
                /*1.absolute*/
                /*宽高不确定的应用*/
                /*width: auto;
                height: auto;
                
                position: absolute;
                left: 50px;
                right: 50px;
                
                top: 20px;
                bottom: 30px;*/
                
                /*2.relative*/
                /*width: 100px;
                height: 100px;
                
                position: relative;
                top: 50px;*/
                
                /*3.fixed*/
                /*width: 100%;
                height: 100px;
                
                position: fixed;
                top: 0px;
                right: 0px;*/
                
                /*4.sticky*/
                /*width: 100%;
                height: 100px;
                
                position: sticky;
                bottom: 0px;*/
                
                width: 100px;
                height: 100px;
                
                position: absolute;
                right: -25px;
                
                
                
            }
            
        </style>
        
    </head>
    <body>
        
        <div id="div1">
            <div id="div2">
                <!--<div style="width: 100px; height: 100px; background-color: honeydew;"></div>-->
                <div id="div3">
                    
                </div>
            </div>
        </div>
        
        <div id="" style="height: 200000px; background-color: slategray;">
            
        </div>
        
        
        
    </body>
</html>

7.盒子模型

html中所有可见的标签都是盒子模型,有固定的结构,包括:内容,padding,border,margin四个部分
内容-可见的,设置width和height实质就是设置内容的大小,默认大小跟标签中的内容有关
添加子标签或者设置文字内容,都是添加或者显示在内容部分的
可以background-color会作用于内容部分
padding-可见的,分上下左右四个部分,一般没有默认都是0,
background-color会作用于padding
border-可见的,分上下左右四个部分,一般默认都是0
border的背景颜色需要单独设置
margin-不可见,但是占位置,分上下左右四个部分,一般默认是0

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style type="text/css">
            #div1{
                /*设置内容部分和padding部分的背景颜色*/
                background-color: hotpink;
                
                /*1.设置内容的大小*/
                width: 100px;
                height: 100px;
                
                /*2.设置padding*/
                /*a.分开设置*/
                /*padding-left: 50px;
                padding-top: 20px;
                padding-right: 20px;
                padding-bottom: 30px;*/
                
                /*b.一起设置*/
                padding: 20px;  /*同时设置四个padding值都为20px*/
                
                /*3.设置border*/
                /*
                 * border值的格式 : 线的样式 颜色 宽度
                 * 线的样式 - solid(实线)\double(双实线)\dashed(点划线)\dotted(虚线)
                 */
                /*border-left: solid blue 13px;
                border-top: solid yellow 10px;
                border-right: solid yellowgreen 12px;
                border-bottom: solid sienna 12px;*/
                /*同时设置*/
                /*border: solid lightskyblue 10px;*/
                
                /*4.设置圆角*/
                
                border-radius: 20px;
                
                /*分开切每个角的圆角*/
                /*border-top-left-radius: 50px;
                border-bottom-right-radius: 50px;
                border-top-right-radius: 50px;*/
                
                /*5.添加margin*/
                margin-left: 20px;
                margin-top: 50px;
                
                
                
                
                                
                
                
                
            }
        </style>
        
    </head>
    <body>
        <div id="" style="width: 100px; height: 200px; background-color: yellow;">
            
        </div>
        <div id="div1">
            <!--俺是看得见福建师范-->
            <div id="" style="width: 20px; height: 20px; background-color: yellowgreen;">
                
            </div>
        </div>
        
        姓名:<input type="text" name="" id="" value="" style="padding-left: 20px;"/>
    </body>
</html>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,290评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,399评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,021评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,034评论 0 207
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,412评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,651评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,902评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,605评论 0 199
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,339评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,586评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,076评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,400评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,060评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,083评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,851评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,685评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,595评论 2 270

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,630评论 1 92
  • 学会使用CSS选择器熟记CSS样式和外观属性熟练掌握CSS各种选择器熟练掌握CSS各种选择器熟练掌握CSS三种显示...
    七彩小鹿阅读 6,272评论 2 66
  • 概述 在网易云课堂学习李南江老师的《从零玩转HTML5前端+跨平台开发》时,所整理的笔记。笔记内容为根据个人需求所...
    墨荀阅读 2,287评论 0 7
  • 01-标准流和浮动 1.标准流 标准流布局:在标准流中,块级标签是一个占一行,默认宽度是父标签的宽度,默认高度是内...
    佐手牵鼬手_89a9阅读 155评论 0 0
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,104评论 1 45