全栈第一步-CSS基础

前言

作为一名后端狗,也有一个全栈梦。前端工程师第一步,CSS的基础得打好。本文仅用于记录上周学习CSS的过程,文中对于CSS知识点可能存在理解错误之处。

CSS基础

CSS主要知识点集中于盒模型,布局,选择器等

盒模型

在对html标签有了整体认识之后,在了解了文档流的概念之后,就得了解元素在整个浏览器中的展现形式。CSS盒模型如下图所示:

css盒模型

从内到外分别为content、padding、border、margin,从盒子模型可知,元素的width和height与padding/border/margin的设置大小有关系,padding,margin等都可以分别设置top、bottom、left、right大小。盒子的整体width、height计算方式比较简单。

目前存在两种不同类型的盒模型,IE盒模型和W3C标准盒模型,区别在于我们在设置的width和height包含哪些部分,从而影响整个盒子的整体高度和宽度的计算。这篇文章对于两种盒模型的区别和计算方法讲得很充分。区别在于IE对于设置的width不仅包含content width,还包含了border和padding。在使用过程中为了统一认识,使用box-sizing:border-box比较好。

上文提到了可以显式设置width、height,目前也存在一些设置width/height不起作用的元素。html元素有块级元素(block-level elements)和行内元素(inline elements)等。在文档流中,块级元素通常被现实为独立的一块,独占一行;inline元素则前后不会产生换行,一系列inline元素都在一行内显示,直到该行排满。

常见的分类有:

常见的块级元素有 DIV, FORM, TABLE, P, PRE, H1~H6, DL, OL, UL 等。

常见的内联元素有 SPAN, A, STRONG, EM, LABEL, INPUT, SELECT, TEXTAREA, IMG, BR 等。

但是我们可以通过设置元素的display属性来改变布局级别。常见的display属性有三种,block、inline、inline-block;区别如下:摘自网络

display:block

block元素会独占一行,多个block元素会各自新起一行。默认情况下,block元素宽度自动填满其父元素宽度。

block元素可以设置width,height属性。块级元素即使设置了宽度,仍然是独占一行。

block元素可以设置margin和padding属性。

display:inline

inline元素不会独占一行,多个相邻的行内元素会排列在同一行里,直到一行排列不下,才会新换一行,其宽度随元素的内容而变化。

inline元素设置width,height属性无效。

inline元素的margin和padding属性,水平方向的padding-left, padding-right, margin-left, margin-right都产生边距效果;但竖直方向的padding-top, padding-bottom, margin-top, margin-bottom不会产生边距效果。

display:inline-block

简单来说就是将对象呈现为inline对象,但是对象的内容作为block对象呈现。之后的内联对象会被排列在同一行内。比如我们可以给一个link(a元素)inline-block属性值,使其既具有block的宽度高度特性又具有inline的同行特性。

布局

布局算是css非常重要的一块应用吧,常见的网页设计可能会分为顶部导航栏,左侧菜单栏,右侧内容区,底部版权声明等。布局主要靠两种属性,float和postion

float

float有几个属性值,left、right,none等,使用float后元素会脱离文档流,使元素display:block,float不会对其上方的元素产生影响,会对其下方的元素产生影响,可以使用clear:both清除影响。

float的属性值有none、left、right,有几个要点:

只有横向浮动,并没有纵向浮动。

当元素应用了float属性后,将会脱离普通流,其容器(父)元素将得不到脱离普通流的子元素高度。

会将元素的display属性变更为block。

浮动元素的后一个元素会围绕着浮动元素(典型运用是文字围绕图片),与应用了position的元素相比浮动元素并不会遮盖后一个元素。

浮动元素的前一个元素不会受到任何影响(如果你想让两个块状元素并排显示,必须让两个块状元素都应用float)。

position

这篇文章对于position和float讲得非常清楚

1、static:默认值。没有定位,元素出现在正常的流中(忽略top,bottom,left,right或者z-index声明)。

2、relative:生成相对定位的元素,通过top,bottom,left,right的设置相对于其正常位置进行定位。可通过z-index进行层次分级。

3、absolute:生成绝对定位的元素,相对于static定位以外的第一个父元素进行定位。元素的位置通过"left","top","right"以及"bottom"属性进行规定。可通过z-index进行层次分级。

4、fixed:生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过"left","top","right"以及"bottom"属性进行规定。可通过z-index进行层次分级。

- fixed这个元素比较重要的一点是参照的对象是浏览器窗口,例如标题栏header或者顶部的导航栏啥的可以选择固定

- fixed与absolute最大的区别就是fixed参照对象是浏览器窗口,而absolute的“根元素”是可以被设置的,默认的话是body标签

static与fixed的定位方式较好理解,在此不做分析。下面对应用的较多的relative和absolute进行分析

比较重要的一点是:

relative是相对于自身位置进行定位,

absolute是相对于static定位以外的第一个父元素进行定位,包括fixed情况。

总结

本文对近期的CSS学习做个总结,总结过程中发现自己对于position定位还不是特别清楚,后续使用过程中得继续体会,接下来准备学习下bootstrap和jquery。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容