前端学习笔记—HTML+CSS布局

学习路线

1、块元素,行内块元素,行内元素定义

image.png

image.png

image.png

image.png

image.png

2、盒子模型

image.png

3、文本操作

image.png

image.png

文本垂直操作:vertical-align的使用图示。middle设置居中。
vertical-align 只对行内元素、行内块元素和表格单元格(table-cell)元素生效:不能用它垂直对齐块级元素

image.png

image.png

image.png

image.png

image.png

4、外边距margin

1.对于行内元素来说,左右的margin是可以完美设置的,上下的margin设置后是无效的。对于行内元素来说,左右的padding是可以完美设置的,上下的padding设置后是会被遮挡。反之块元素和行内块元素则正常。
2.给一个固定宽高的块级元素左右margin-left,margin-right设置auto可以实现该元素在其父容器里面水平左右居中,反之设置竖直方向的margin则竖直方向居中。但是行内元素设置无效,因为行内元素无法设置宽高生效。
3.父容器开启flex布局,子容器margin:auto;也可以设置设置子容器居中。

image.png

5、塌陷问题

  • 父子元素间margin上下方向异常俗称“塌陷”
    1.float引起的父容器“塌陷”问题,而自己本身不会塌陷。自己当前元素脱离文档流后,不再能撑起父元素的高度,导致父元素高度塌陷,但父元素的宽度依然束缚浮动的子元素。解决方法见文章下方浮动解析,如设置父元素清除浮动。
    2.设置float浮动后的元素不会出现内部子元素上下margin合并问题,也可以清除第一个子元素上边距和最后一个子元素下边距被父元素剥夺问题。

    image.png

  • 兄弟元素之间,上下发生重叠合并margin-top和margin-bottom的问题,它们的距离会合并取其中最大的一个值。
    1.无需特殊解决,只需设置一个方向的margin-top或margin-bottom其中之一即可
    2.可以在元素多套一个父容器,给父容器设置overflow:hidden

    image.png

6、内容溢出问题

image.png

image.png

7、样式继承

image.png

8、元素空白问题,x基线对齐导致处理

image.png

image.png

9、浮动float

  • 创建的初衷是为了实现文字环绕效果,也就导致浮动模块盖住的区域内的文字会被挤出来到浮动模块外展示给用户观看。
  • 定位功能可以代替大部分浮动实现效果。定位模块式:相对定位(relative),绝对定位( absolute),固定定位(fixed),粘性定位(sticky),默认定位模式static。


    image.png

    image.png

    image.png
image.png

image.png
清楚浮动影响,通过对父容器末尾添加一个伪元素,设置内容空字符
parent::after{
content :"";
display: block;
clear :both;
}
image.png

10、 定位

定位元素(positioned element)是其计算后位置属性为 relative, absolute, fixedsticky 的一个元素(换句话说,除static以外的任何东西)。

  • 默认定位元素static按照正常文档流布局,不会影响浮动(float)属性的生效。
  • 相对定位元素(relatively positioned element)是计算后位置属性为 relative的元素,会占用原来位置并留下空白。同时设置的float浮动生效,且浮动优先级更高。
  • 绝对定位元素(absolutely positioned element)是计算后位置属性为 absolute 的元素。绝对定位必须是作用于父级或往上的层级非static模式的布局里面才生效。同时设置的float浮动失效。
  • 固定定位元素 fixed 的元素相对于视口html定位,且不随视口滚动而滑动,不占原来的位置。同时设置的float浮动失效。
  • 粘性定位元素(stickily positioned element)是计算后位置属性为 sticky 的元素。不能同时设置的float浮动,否则定位不生效。
    注:所有的定位都是同一层级。建议大模块用浮动,微调用定位。
定位1.png

定位元素与float浮动的关系


定位2.png

定位3.png

定位4.png

定位5.png

定位6.png

定位7.png

定位8.png

定位9.png

定位10.png

定位11.png

定位12.png

给一个span行内元素设置宽高是不生效的,有特殊情况可以如下操作可以使行内元素块状化:

  • 通过设置absolute绝对定位和fixed固定定位后设置span宽高可以生效,其它定位方式不生效
  • 设置display: inline-block;行内块元素设置span宽高可以生效
image.png

image.png
  • 绝对定位和固定定位margin的居中方式,在设置了宽高后,可以居中。不设置宽高,则充满父容器。
  • transform: translateX(-50%);平移的居中方式,不用设置宽高。


    image.png

11、元素变换transform

移动盒子模型位置的方法 :

  • transform: translate 中可以传入百分比值 , 百分比是相对于元素自身尺寸来说的 ;
  • 通过定位样式移动盒子 : 相对定位 relative 样式 , 绝对定位 absolute 样式 ;
  • 通过设置盒子外边距 : 外边距 margin样式 ;
  • 2D 转换中的 Translate 移动 ; transform: translate() 样式 ;
  • Translate 移动 相对于其它方式 移动盒子模型 的优点 : 使用 Translate 移动标签元素 , 不会影响其它元素的位置 , 不会脱标 ;
  • Translate 只能移动块级元素 , 对于 行内元素 / 行内块元素 是无效的 ;
image.png
image.png

12、弹性盒子模型flex

  • 弹性盒子又叫伸缩盒模型,或者叫开启flex模式。子元素默认沿着主轴方向排列。
  • 定位元素与弹性盒子都会变成“行内块”化,弹性盒子作用于子元素,定位元素作用于自身。


    image.png
image.png
image.png
image.png
image.png

浮动与弹性盒子选择上的区别:
浮动(float):可以让元素同行显示,元素排列不下时会自动让元素换行显示。
弹性容器(display: flex):可以让元素同行显示,元素排列不下时不会自动换行,而是将元素进行压缩排列显示,除非设置flex-warp属性才会换行显示。

flex(弹性盒子)
采用flex布局的元素,称为flex容器;这个容器的子元素称为flex项目。
格式:display: flex; 写在父级元素(容器)里
容器属性
1. flex-direction: 主轴方向
2. flex-wrap: 主轴一行满了换行
3. flex-flow: 1和2的组合
4. justify-content: 主轴元素对齐方式
5. align-items: 交叉轴元素对齐方式//单行
6. align-content: 交叉轴行对齐方式//多行
image.png

image.png

侧轴:
align-items:stretch;属性是单行子元素默认值,在不设置固定高度的时候,侧轴方向高度自动充满父容器。子元素设置固定高度时,与flex-start效果一样。
align-content:stretch;属性是多行子元素默认值,在不设置固定高度的时候,侧轴方向高度自动平分父容器。子元素设置固定高度时,与flex-start效果一样。

image.png

image.png
image.png
image.png
image.png

13、border边框使用

  • box-sizing设置
    content-box:
    padding不被包含在定义的width和height之内。对象的实际宽度等于设置的width值和border、padding之和,即 ( Element width = width + border + padding)
    此属性表现为标准模式下的盒模型。

  • border-box设置
    padding和border被包含在定义的width和height之内。对象的实际宽度就等于设置的width值,即使定义有border和padding也不会改变对象的实际宽度,即 ( Element width = width )

    image.png

14、拉伸和压缩

image.png
image.png
image.png

15、响应式布局

  • 可以设置在不同的媒体特征下时,显示不同的样式。如屏幕宽度达到小于(max-width)一个临界值的时候,显示手机移动版网页等;大于(min-width)一个临界值则显示pc端网页样式。


    媒体查询特征.png
媒体类型.png
媒体运算符.png
image.png

16、BFC功能---全称:块级格式化上下文

开启BFC.png
开启BFC.png

17、布局技巧

可以通过margin,text-align:center,vertical-align:middle,定位布局,flex弹性盒子,transform平移等方式实现居中效果。

1.居中父容器

》方式1:绝对定位和固定定位margin的居中方式,在设置了宽高后,可以居中。不设置宽高,则充满父容器。
子元素{
  left:0;
  right :0;
  top :0;
  bottom:0;
  margin :auto;
}

》方式2:transform属性平移
父元素{  
  position: relative; 
 }
子元素 {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
}

》方式3:使用flex弹性布局,简单
父元素{  
  display: flex;
  flex-direction: column;//主轴方向:默认column垂直方向,row水平方向
  justify-content: center;//主轴方向居中
  align-items: center;//侧轴方向居中
}
2.其他水平居中方式

》方式1:若子元素为块元素,给子元素加上:margin:0 auto 注意子元素只能是块级元素才能生效。

》方式2:text-align:center方式,若子元素为行内元素、行内块元素,给父元素加上:text-align:center 因为行内块和行内元素可以当做文本元素设置。

》方式3:transform: translateX(-50%);平移的居中方式,不用设置宽高。
父元素{  
  position: relative; 
}
子元素 {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
3.其他垂直居中方式

》方式1:若子元素为块元素,给子元素加上: margin-top ,值为:(父元素 content - 子元素盒子总高)/2
》方式2:vertical-align:middle方式,若子元素为行内元素、行内块元素
让父元素的 height = line-height高度,每个子元素都加上:vertical-align:middle;
补充:若想绝对垂直居中,父元素 font-size 设置为0。
image.png

18、伪类

伪类操控现有盒子元素。伪元素操作内容子元素,对子元素增加、删除,设置样式等。


动态伪类.png

结构伪类.png

:nth-of-type()
nth-of-type他是当前元素的同类型兄弟元素的第n个,而nth-child是当前元素的兄弟节点的第n个当前元素

<html>
<head>
    <meta charset="utf-8">
    <title>伪类</title>
    <style>
        //nth-of-type同类型的兄弟元素
        .province:nth-of-type(4) {
            color: red
        }
        //当前元素的所有的兄弟节点的第n个元素
        .province:nth-child(4) {
            color: green
        }
    </style>
</head>
<body>
    <div class="province">
        111
    </div>
    <li>
        222
    </li>
    <div class="province">
        333
    </div>
    <div class="province">
        444,:nth-child(4)
    </div>
    <div class="province">
        555,:nth-of-type(4)
    </div>
    <div class="province">
        666
    </div>
    <input type="button" value="加载新文档" onclick="newDoc()">
</body>
</html>
image.png
伪类.png

视频:尚硅谷前端入门html+css零基础教程,零基础前端开发html5+css3视频

【狂神说Java】CSS3最新教程快速入门通俗易懂

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容