「学习笔记」CSS基础(1)

「学习笔记」CSS基础(1)

像素量出来老是不对的,是因为你的windows系统,设置的缩放不是百分之100
vscode小技巧:

  1. alt+鼠标单击,alt+shift+鼠标左键按住移动
  2. 在vscode中打开图片,右下角可以看到宽高的像素值

CSS构造块
「1. HTML的局限性」

HTML满足不了设计者的需求,可以将网页结构与样式相分离,这样就可以在不更改网页结构的前提下,更换网站的样式。
操作html属性不方便
HTML里面添加样式带来的是无尽的臃肿和繁琐
「2. CSS网页的美容师」

让我们的网页更加丰富多彩,布局更加灵活自如。
CSS最大的贡献:让HTML从样式中脱离,实现了HTML专注去做结构呈现,样式交给CSS
「3. CSS」CSS(Cascading Style Sheets)通常称为CSS样式表或层叠样式表(级联样式表)。

作用
主要用于设置HTML页面中的文本内容(字体、大小、对齐方式等)\图片的外形(宽高、边框样式、边距等)以及版面的布局和外观显示样式。
CSS以HTML为基础,提供了丰富的功能,如字体、样式、背景的控制及整体排版等,而且可以针对不同的浏览器设置不同的样式。
「4. CSS注释」
/* 这是注释 */

引入CSS样式表

「1.行内式(内联样式)」

通过标签的style属性来设置元素的样式

style其实就是标签的属性
样式属性和值中间是:
多组属性值直接用;隔开
只能控制当前的标签和以及嵌套在其中的字标签,造成代码冗余。
缺点:没有实现样式和结构相分离。

<标签名 style="属性1:属性值1; 属性2:属性值2; 属性3:属性值3;"> 内容 </标签名>
例如:
<div style="color: red; font-size: 12px;">青春不常在,抓紧谈恋爱</div>

「2.内部样式表(内嵌样式表)」

也称为内嵌式,将CSS代码集中写在HTML文档的head头部标签中,并且用style标签定义。

style标签一般位于head标签中,当然理论上他可以放在HTML文档的任何地方(例如放body最下面也可以)。
type=“text/css” 在html5中可以省略。
只能控制当前的页面
缺点:没有彻底分离结构与样式

<head>
<style type="text/CSS">
    选择器(选择的标签) { 
      属性1: 属性值1;
      属性2: 属性值2; 
      属性3: 属性值3;
    }
</style>
</head>

「3.外部样式表(外链式)」

也称链入式,是将所有的样式放在一个或多个以.css为扩展名的外部样式表文件中,通过link标签将外部样式表文件链接到HTML文档中。

rel:定义当前文档与被链接文档之间的关系,在这里需要指定为“stylesheet”,表示被链接的文档是一个样式表文件。
href:定义所链接外部样式表文件的URL,可以是相对路径,也可以是绝对路径。

<link rel="stylesheet" href="index.css">

「4.团队约定-代码风格」

/*1.紧凑格式 (Compact)*/
h3 { color: deeppink;font-size: 20px;}
// 2.一种是展开格式(推荐)
h3 {
 color: deeppink;
    font-size: 20px;    
}

/* 团队约定-代码大小写*/
/* 样式选择器,属性名,属性值关键字全部使用小写字母书写,属性字符串允许使用大小写。*/
/* 推荐 */
h3{
 color: pink;
}
 
/* 不推荐 */
H3{
 COLOR: PINK;
}

CSS基础选择器

CSS选择器作用
找到指定的HTML页面元素,选择标签。

「1. 标签选择器」

标签选择器(元素选择器)是指用HTML标签名称作为选择器,按标签名称分类,为页面中某一类标签指定统一的CSS样式。
作用:可以把某一类标签全部选择出来。
优点:快速为网页中同类型的标签统一样式
缺点:不能设计差异化样式。

标签名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; } 

「2. 类选择器」

类选择器使用"."(英文点号)进行标识,后面紧跟类名。
语法:类名选择器

.类名  {   
    属性1:属性值1; 
    属性2:属性值2; 
    属性3:属性值3;     
}
<p class='类名'></p>

优点:可以为元素对象定义单独或相同的样式。可以选择一个或者多个标签。
注意:类选择器使用“.”(英文点号)进行标识,后面紧跟类名(自定义,我们自己命名的)
长名称或词组可以使用中横线来为选择器命名。
不要纯数字、中文等命名, 尽量使用英文字母来表示。
多类名选择器:各个类名中间用空格隔开。

「3. id选择器」id选择器使用#进行标识,后面紧跟id名

元素的id值是唯一的,只能对应于文档中某一个具体的元素。

#id名 {属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }
<p id="id名"></p>

「4. 通配符选择器」

通配符选择器用号表示, 就是选择所有的标签。它是所有选择器中作用范围最广的,能匹配页面中所有的元素。

注意:会匹配页面所有的元素,降低页面响应速度,不建议随便使用

* { 属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

例如下面代码,使用通配符选择器定义CSS样式,清除所有HTML标记的默认边距。

* {
  margin: 0;                    /* 定义外边距*/
  padding: 0;                   /* 定义内边距*/
}

「5. 基础选择器总结」

选择器作用缺点使用情况用法
标签选择器可以选出所有相同的标签,比如p不能差异化选择较多p { color:red;}
类选择器可以选出1个或者多个标签可以根据需求选择非常多.nav { color: red; }
id选择器一次只能选择器1个标签只能使用一次不推荐使用#nav {color: red;}
通配符选择器选择所有的标签选择的太多,有部分不需要不推荐使用* {color: red;}

「6. 团队约定-选择器」

尽量少用通配符选择器 *。
尽量少用ID选择器
不使用无具体语义定义的标签选择器。

/* 推荐 */
.jdc {}
li {}
p{}

/* 不推荐 */
*{}
#jdc {}
div{}   因为div 没有语义,我们尽量少用

CSS复合选择器

复合选择器是由两个或多个基础选择器,通过不同的方式组合而成的

「1. 后代选择器」又称为包含选择器

用来选择元素或元素组的子孙后代
其写法就是把外层标签写在前面,内层标签写在后面,中间用「空格」分隔,先写父亲爷爷,再写儿子孙子。
子孙后代都可以这么选择。或者说,它能选择任何包含在内 的标签。

会把所有后代都选上,例如.class h1,会把.class里面的所有h1都选上

父级 子级{属性:属性值;属性:属性值;}

.class h3 {color:red;font-size:16px;}

在这里插入图片描述
当标签发生嵌套时,内层标签就成为外层标签的后代。
子孙后代都可以这么选择。或者说,它能选择任何包含在内的标签。

「2. 子元素选择器」

子元素选择器只能选择作为某元素子元素(亲儿子)的元素。
其写法就是把父级标签写在前面,子级标签写在后面,中间跟一个 > 进行连接
这里的子,指的是亲儿子。不包含孙子 重孙子之类。

例如.class>h3,只会选择.class里所有最近一级的h3(亲儿子,不包括孙子)

.class>h3 {color:red;font-size:14px;}

「3. 交集选择器」

在这里插入图片描述
其中第一个为标签选择器,第二个为class选择器,两个选择器之间不能有空格,如h3.special。

交集选择器是并且的意思,即...又...的意思
比如:   p.one   选择的是: 类名为 .one 的段落标签。 
/*用的相对来说比较少,不建议使用。*/

「4. 并集选择器」

如果某些选择器定义的相同样式,就可以利用并集选择器,可以让代码更简洁。并集选择器(CSS选择器分组)是各个选择器通过,连接而成的,通常用于集体声明。

任何形式的选择器(包括标签选择器、class类选择器 id选择器等),都可以作为并集选择器的一部分。
并集选择器通常用于集体声明 ,逗号隔开的,所有选择器都会执行后面样式,逗号可以理解为和的意思。

任何形式的选择器都可以作为并集选择器的一部分(包括后代、子元素选择器等)。

        div,
        p,
        .pig li {
            color: pink;
        }
表示 div 和 p  和 .pig li(后代选择器) 这三个选择器都会执行颜色为粉色。 
通常用于集体声明。  

「5. 链接伪类选择器」

用于向某些选择器添加特殊的效果,比如给链接添加特殊效果,或选择第1个,第n个元素。
伪类选择器书写最大的特点是用冒号(:)表示,比如:hover、:first-child
伪类选择器有很多,比如链接伪类、结构伪类等。(现在介绍的是链接伪类)

注意事项:

  1. 为了确保生效,请按照LVHA的顺序声明:link - :visited - :hover - :active。(按下方的顺序书写)
    <style>
        /* 1.未访问的链接 a:link  把没有点击过的(访问过的)链接选出来 */
        a:link {
            color: #333;
            text-decoration: none;
        }

        /*2. a:visited 选择点击过的(访问过的)链接 */
        a:visited {
            color: orange;
        }

        /*3. a:hover 选择鼠标经过的那个链接 */
        a:hover {
            color: skyblue;
        }

        /* 4. a:active 选择的是我们鼠标正在按下还没有弹起鼠标的那个链接 */
        a:active {
            color: green;
        }
    </style>

链接伪类,是利用交集选择器.

a:link 选择所有未被访问的链接
a:visited 选择所有已被访问的链接
a:hover 选择鼠标指针位于其上的链接
a:active 选择活动链接(鼠标按下未弹起的链接)
实际工作中,很少写全四个状态,一般写法如下:

a {   /* a是标签选择器  所有的链接 */
   font-weight: 700;
   font-size: 16px;
   color: gray;
      text-decoration: none; /* 清除链接默认的下划线*/
}
a:hover {   /* :hover 是链接伪类选择器 鼠标经过 */
   color: red; /*  鼠标经过的时候,由原来的 灰色 变成了红色 */
}
/* 如果a标签的class是xxx,也可以这么写 */
.xxx :hover {   
   color: red; 
}

「6. :focus伪类选择器」

:focus伪类选择器用于选取获得焦点的表单元素。
焦点就是光标,一般情况<input>类表单元素才能获取,因此这个选择器也主要针对于表单元素来说。

    <style>
        /* // 把获得光标的input表单元素选取出来 */
        input:focus {
            background-color: pink;
            color: red;
        }
    </style>

「6. 复合选择器总结」

选择器作用特征使用情况隔开符号及用法
后代选择器用来选择元素后代是选择所有的子孙后代较多符号是空格 .nav a
子代选择器选择 最近一级元素只选亲儿子较少符号是> .nav>p (下拉菜单等会用到)
交集选择器选择两个标签交集的部分既是 又是较少没有符号 p.one
并集选择器选择某些相同样式的选择器可以用于集体声明较多符号是逗号 .nav, .header
链接伪类选择器给链接更改状态跟链接相关较多重点记住 a{} 和 a:hover 实际开发的写法
:focus选择器选择获得光标的表单跟表单相关较少input:focus 记住这个写法

CSS字体样式

font字体

「1. font-size」

font-size属性用于设置字号(字体大小)
谷歌浏览器默认的文字大小为16px
不同浏览器可能默认显示的字号大小不一致,我们尽量给一个明确值大小,不要默认大小。一般给body指定整个页面文字的大小。

p { font-size:20px; }

单位
相对长度单位、绝对长度单位
在这里插入图片描述

「2. font-family」

font-family属性用于设置哪一种字体,通常给body指定。

p { font-family:"微软雅黑";}

指定多个字体,如果浏览器不支持第一个字体就会尝试下一个直到找到合适的字体,如果都没有,以电脑默认字体为准。

p {font-family: Arial,"Microsoft Yahei", "微软雅黑";}

CSS Unicode字体
在 CSS 中设置字体名称,直接写中文是可以的。但是在文件编码(GB2312、UTF-8 等)不匹配时会产生乱码的错误。
xp 系统不支持 类似微软雅黑的中文。
解决方案:英文来替代。比如font-family:“Microsoft Yahei”。在 CSS 直接使用 Unicode 编码来写字体名称可以避免这些错误。使用 Unicode 写中文字体名称,浏览器是可以正确的解析的。

font-family: "\5FAE\8F6F\96C5\9ED1";   表示设置字体为“微软雅黑”。
「3. font-weight」

可以让默认加粗的标签不加粗,或者其他标签加粗。

属性值描述
normal默认值(不加粗的)
bold定义粗体(加粗的)
100~900 (后面不要加单位)400 等同于 normal,而 700 等同于 bold (数字表示粗细用的多)
「4. font-style」

font-style属性用于定义字体风格,如设置斜体、倾斜或正常字体,其可用属性值如下:

属性作用
normal默认值,浏览器会显示标准的字体样式 font-style: normal;
italic浏览器会显示斜体的字体样式。
「5. font:综合设置字体样式」
选择器 { font: font-style  font-weight  font-size/line-height  font-family;}

行高后加单位就是指定行高多少,不跟单位行高就是文字大小*x倍(所有子元素都会继承)。
注意:使用font属性时,必须按上面语法格式中的顺序书写,不能更换顺序,各个属性以空格隔开
其中不需要设置的属性可以省略(取默认值),但必须保留font-size和font-family属性,否则font属性将不起作用。

「6. font总结」
属性表示注意点
font-size字号我们通常用的单位是px 像素,一定要跟上单位
font-family字体实际工作中按照团队约定来写字体
font-weight字体粗细记住加粗是 700 或者 bold 不加粗 是 normal 或者 400 记住数字不要跟单位
font-style字体样式记住倾斜是 italic 不倾斜 是 normal 工作中我们最常用 normal
font字体连写1. 字体连写是有顺序的 不能随意换位置 2. 其中字号 和 字体 必须同时出现

CSS文本外观属性

「1. color」文本的颜色

color属性用于定义文本的颜色
其取值方式有以下3种:

实际工作中,用16进制的写法是最多的,且我们更喜欢简写方式比如#f0代表红色。

标识表示属性值
预定义的颜色值red,green,blue,pink
十六进制#FF0000,#FF6600,#29D794
RGB代码rgb(255,0,0)或rgb(100%,0%,0%)
「2.text-align」水平对齐方式(设置水平居中)

text-align属性用于设置文本内容的水平对齐方式,相当于html中的align对齐属性。

注意:是让盒子里面的文本内容水平居中, 而不是让盒子居中对齐

其可用属性值如下:

属性解释
left左对齐(默认值)
right右对齐
center居中对齐
「3. line-height」行间距(行高)(设置垂直居中)

用于设置行与行之间的距离,即字符的垂直间距,一般称为行高。

line-height常用的属性值单位有三种,分别为像素px,相对值em和百分比%,实际工作中使用最多的是像素px

一般情况下,行距比字号大7--8像素左右就可以了。
line-height: 24px;
行高测量方法

css没有提供文字垂直居中的代码,可以让文字的行高等于盒子的高度来实现文字在当前盒子内垂直居中。

小工具:FSCapture
在这里插入图片描述
在这里插入图片描述

行高我们利用最多的一个地方是:可以让单行文本在盒子中垂直居中对齐。

文字的行高等于盒子的高度。行高 = 上距离 + 内容高度 + 下距离
上距离和下距离总是相等的,因此文字看上去是垂直居中的。

在这里插入图片描述
行高与高度的三种关系
如果行高 等于盒子 高度 文字会 垂直居中
如果行高 大于 盒子高度 文字会 偏下
如果行高小于盒子高度 文字会 偏上
在这里插入图片描述

  /*line-height 要设置在font属性下面,否则无效,例如:*/
  height: 80px;
  text-align: center;
  font: normal bold 30px "宋体";
  line-height: 80px;

可以使用display:flex;布局方式让文字水平垂直居中

  display: flex;
  align-items: center;     /* 侧轴对齐方式*/
  justify-content: center; /* 主轴对齐方式 */
「4. text-indent」首行文本的缩进

text-indent属性用于设置首行文本的缩进

其属性值可为不同单位的数值、em字符宽度的倍数、或相对于浏览器窗口宽度的百分比%,允许使用负值。
建议使用em作为设置单位。

em是一个相对单位,就是当前元素(font-size)1个文字的大小,如果当前元素没有设置大小,则会按照父元素的1个文字大小。例如当前段落文字大小是16px,那么1em就是16px,可以写小数,如1.5em

p {
      /*行间距*/
      line-height: 25px;
      /*首行缩进2个字  em  1个em 就是1个字的大小*/
      text-indent: 2em;  
 }
「5. text-decoration」文本的装饰(下划线、删除线等)

text-decoration,通常我们用于给链接修改装饰效果
可以去掉a标签的下划线

描述
none默认。定义标准的文本。取消下划线(最常用)
underline定义文本下的一条线。下划线 也是我们链接自带的(常用)
overline定义文本上的一条线。(不用)
line-through定义穿过文本的一条线。(不常用)
「6. CSS外观属性总结」
属性表示注意点
color颜色我们通常用 十六进制 比如 而且是简写形式 #fff (简写#ff00ff → #f0f 如果两两相同则可简写,红绿蓝)
line-height行高控制行与行之间的距离
text-align水平对齐可以设定文字水平的对齐方式,(如果要让图片居中对齐,可以给父元素加)
text-indent首行缩进通常我们用于段落首行缩进2个字的距离 text-indent: 2em;
text-decoration文本修饰记住 添加 下划线 underline 取消下划线 none

Chrome调试工具

  1. 呼出调试工具,可以右键检查,或按f12
  2. ctrl+滚轮可以放大缩小开发者工具代码大小
  3. 如果选择了元素,右边没有出现样式,可能是元素引用错了样式
  4. 如果出现一个删除线,且有黄色警告,可能是样式书写错误

Emmet语法

emmet语法的前身是Zen coding,它使用缩写,来提高html/css的编写速度,vscode内部已经集成该语法。

  1. 快速生成HTML结构语法
  2. 快速生成css样式语法
  3. 地址

css 的元素显示模式

标签显示模式是元素(标签)以什么方式进行显示。HTML标签一般分为块元素行内元素两种类型

「1. 块级元素(block-level)」

常见的块元素有<h1>~<h6>、<p>、<div>、<ul>、<ol>、<li>等,其中<div>标签是最典型的块元素。

块级元素的特点 :

  • 独占一行
  • 高度,宽度,外边距以及内边距都可以控制。
  • 宽度默认是容器(父级宽度)的100%(不给宽度默认就和父级一样宽,高度用自己的)
  • 是一个容器及盒子,里面可以放行内或者块级元素
  • 注意:文字类的元素内不能使用块级元素,因此p标签里面不能放块级元素,特别是p不能放div。同理,还有h1~h6,dt,它们都是文字类块级标签,里面不能放其他块级元素。
「2. 行内元素(inline-level)」

有的地方也称为内联元素
常见的行内元素有<a>、<strong>、<b>、<em>、<i>、<del>、<s>、<ins>、<u>、<span>等,其中<span>标签最典型的行内元素。

行内元素的特点 :

  1. 相邻行内元素在一行上,一行可以显示多个。
  2. 高度、宽度直接设置是无效的。
  3. 默认高度就是它本身内容的宽度。
  4. 行内元素只能容纳文本或其他行内元素。

注意

  • 链接里面不能再放链接
  • 特殊情况a里面可以放块级元素,但是给a转换一下块级模式最安全。
「3. 行内块元素(inline-block)」

在行内元素中有几个特殊的标签——<img>、<input >、<td>,可以对它们设置宽高和对齐属性,有些资料可能会称它们为行内块元素。

行内块元素的特点:

  1. 和相邻行内元素(行内块)在一行上,但是之间会有空白缝隙。一行可以显示多个(行内元素特点)
  2. 默认宽度就是它本身内容的宽度(行内元素特点)。
  3. 高度,行高,外边距以及内边距都可以控制(块级元素特点)。
三种模式总结
元素模式元素排列设置样式默认宽度包含
块级元素一行只能放一个块级元素可以设置宽度高度容器的100%容器级可以包含任何标签
行内元素一行可以放多个行内元素不可以直接设置宽度高度它本身内容的宽度容纳文本或则其他行内元素
行内块元素一行放多个行内块元素可以设置宽度和高度它本身内容的宽度

标签显示模式转换 display

  1. 块转行内:display:inline;
  2. 行内转块:display:block;
  3. 块、行内元素转换为行内块:display: inline-block;

1、3用的较多,例如给a标签增加点击范围,转块级。

snipaste工具推荐

常用快捷方式:

  1. F1可以截图,同时测量大小,设置箭头,书写文字等。
  2. F3在桌面置顶显示
  3. 点击图片,alt可以取色(按shift可以切换取色模式)
  4. 按esc取消图片显示

CSS背景(background)

「1. 背景颜色」
background-color: 颜色值;   默认的值是 transparent  透明的
「2. 背景图片(image)」

实际开发常见于logo或者一些装饰性的小图片或者是超大的背景图片,优点是非常便于控制位置(精灵图也是一种运用场景)

语法:
background-image : none | url (url) ;
例如:
background-image: url(images/1.png);
「3. 背景平铺(repeat)」

背景既图片和背景颜色同时加,背景颜色在盒子最底层,背景图片会压住背景颜色

background-repeat : repeat | no-repeat | repeat-x | repeat-y 
参数作用
repeat背景图像在纵向和横向上平铺(默认的)
no-repeat背景图像不平铺(不重复显示,其他3个都是会重复显示的)
repeat-x背景图像在横向上平铺
repeat-y背景图像在纵向平铺
「4. 背景位置(position)」

在这里插入图片描述
一般用于文字前面的小图标(小的装饰性图片),例如上图案例,如果直接在h3中放img标签,图片位置比较难调,用背景图片的方式方便图片定位。

    <style>
        div {
            width: 300px;
            height: 300px;
            background-color: pink;
            background-image: url(images/logo.png);
            background-repeat: no-repeat;
            /* background-position:  方位名词; */
             background-position: center top; 
             background-position: right center; 
            /* 如果是方位名词  right center 和 center right 效果是等价的 跟顺序没有关系 */
             background-position: center right; 
            /* 此时 水平一定是靠右侧对齐  第二个参数省略 y 轴是 垂直居中显示的 */
             background-position: right; 
            /* 此时 第一个参数一定是 top y轴 顶部对齐   第二个参数省略x  轴是 水平居中显示的 */
            background-position: top;
        }
    </style>

超大背景图片案例,横向超出盒子大小或屏幕大小

    <style>
        body {
            background-image: url(images/bg.jpg);
            background-repeat: no-repeat;
            background-position: center top; 
        }
    </style>
参数
length百分数、由浮点数字和单位标识符组成的长度值
no-repeattop(上对齐) 、center(居中对齐) 、bottom(下对齐) 、left (左对齐)、 right (右对齐) 方位名词

注意:

  • 必须先指定background-image属性
  • position 后面是x坐标和y坐标。可以使用方位名词或者 精确单位
  • 如果指定两个值,两个值都是方位名字,则两个值前后顺序无关,比如left top和top left效果一致
  • 如果只指定了一个方位名词,另一个值默认居中对齐。
  • 如果position 后面是精确坐标, 那么第一个,肯定是 x 第二个一定是y
  • 如果只指定一个数值,那该数值一定是x坐标,另一个默认垂直居中
  • 如果指定的两个值是 精确单位和方位名字混合使用,则第一个值是x坐标,第二个值是y坐标

背景图像固定(背景附着):
background-attachment 属性设置背景图像是否固定或者随着页面其余部分滚动。

背景简写:

  • background:属性的值的书写顺序官方没有强制的标准。为了可读性,建议如下写:
  • background: 背景颜色 背景图片地址 背景平铺 背景滚动 背景位置;
/* 有背景图片背景颜色可以不用写*/
background: transparent url(image.jpg) repeat-y  scroll center top ;
「5. 背景色半透明(CSS3)」

rgba,r:红,g:绿,b:蓝,a:透明度,括号中的数字分别对应这4个值

background: rgba(0, 0, 0, 0.3);
//可省略0.3的0
background: rgba(0, 0, 0, .3);
  • 等同于background-color: rgba(0, 0, 0, .3)
  • 最后一个参数是alpha 透明度 取值范围 0~1之间
  • 我们习惯把0.3 的 0 省略掉 这样写 background: rgba(0, 0, 0, .3);
  • 注意:背景半透明是指盒子背景半透明,盒子里面的内容不受影响
  • 低于IE 9的版本不支持

盒子半透明 opacity

  • 设置opacity元素的所有后代元素会随着一起具有透明性,一般用于调整图片或者模块的整体不透明度
opacity: .2;
「6. 背景总结」
属性作用
background-color背景颜色预定义的颜色值/十六进制/RGB代码
background-image背景图片url(图片路径)
background-repeat是否平铺repeat/no-repeat/repeat-x/repeat-y
background-position背景位置length/position 分别是x 和 y坐标, 切记 如果有 精确数值单位,则必须按照先X 后Y 的写法
background-attachment背景固定还是滚动scroll(背景图像是随对象内容滚动,默认值)、fixed(背景图像固定)
背景简写 background: (开发中更提倡的写法)书写更简单不像font有顺序要求,什么顺序都可以,但是一般约定: 背景颜色、 背景图片地址 、背景平铺 、背景图片滚动 、背景图片位置; 的顺序书写。
背景透明让盒子半透明background: rgba(0,0,0,0.3); 后面必须是 4个值

CSS三大特性

「1. CSS 层叠性」

在这里插入图片描述

  • 概念:

    • 所谓层叠性是指多种CSS样式的叠加
    • 是浏览器处理冲突的一个能力,如果一个属性通过两个相同选择器设置到同一个元素上,那么这个时候一个属性就会将另一个属性层叠掉
  • 原则:

    • 样式冲突,遵循的原则是就近原则。 那个样式离着结构近,就执行那个样式。
    • 样式不冲突,不会层叠。

「2. CSS 继承性」

在这里插入图片描述

  • 概念:

    • 子标签会继承父标签的某些样式,如文本颜色和字号。
    • 想要设置一个可继承的属性,只需将它应用于父元素即可。
  • 注意:

    • 恰当地使用继承可以简化代码,降低CSS样式的复杂性。比如有很多子级孩子都需要某个样式,可以给父级指定一个,这些孩子继承过来就好了。
    • 子元素可以继承父元素的样式(text-,font-,line-这些元素开头的可以继承,以及color属性)
    <style>
        body {
            color: pink;
            /* font: 12px/24px 'Microsoft YaHei'; */
            font: 12px/1.5 'Microsoft YaHei';
        }
        div {
            /* 子元素继承了父元素 body 的行高 1.5 */
            /* 这个1.5 就是当前元素文字大小 font-size 的1.5倍   所以当前div 的行高就是21像素 */
            font-size: 14px; 
        }
        p {
            /* 1.5 * 16 =  24 当前的行高 */
            font-size: 16px;
        }
        /* li 没有手动指定文字大小  则会继承父亲的 文字大小  body 12px 所以 li 的文字大小为 12px 
        
        当前li 的行高就是  12 * 1.5  =  18
        */
    </style>

「3. CSS 优先级(CSS特殊性)」

在这里插入图片描述

  • 概念:定义CSS样式时,经常出现两个或更多规则应用在同一元素上,此时,

    • 选择器相同,则执行层叠性
    • 选择器不同,则根据选择器权重执行
  • 权重计算公式:

标签选择器计算权重公式
继承或者 *0,0,0,0
元素选择器(标签选择器)0,0,0,1
类选择器,伪类选择器0,0,1,0
ID选择器0,1,0,0
行内样式 style=""1,0,0,0
!important 重要的∞ 无穷大
  • 值从左到右,左面的最大,一级大于一级,数位之间没有进制,级别之间不可超越。
  • 关于CSS权重,我们需要一套计算公式来去计算,这个就是 CSS Specificity(特殊性)
  • div { color: pink !important; }
  • 权重叠加(不会有进位):
 div ul  li   ------>    0,0,0,1 + 0,0,0,1 + 0,0,0,1 =  0,0,0,3
 .nav ul li   ------>    0,0,1,0 + 0,0,0,1 + 0,0,0,1 =   0,0,1,2
 a:hover      -----—>      0,0,1,1
 .nav a       ------>      0,0,1,1
  • 继承的权重是0,不管父元素权重多高:

    • 我们修改样式,一定要看该标签有没有被选中
    • 如果选中了,那么以上面的公式来计权重。谁大听谁的。
    • 如果没有选中,那么权重是0,因为继承的权重为0.

a标签比较特殊,a链接浏览器默认制定了一个样式 蓝色的 有下划线 a {color: blue;},所以继承过来的字体颜色不起作用,要单独设置。

    <style>
        /* 父亲的权重是 100  */
        #father {
            color: red!important;
        }
        /* p继承的权重为 0 */
        /* 所以以后我们看标签到底执行那个样式,就先看这个标签有么有直接被选出来 */
        p {
            color: pink;
        }
        body {
            color: red;
        }
        /* a链接浏览器默认制定了一个样式 蓝色的 有下划线  a {color: blue;}*/
        a {
            color: green;
        }
    </style>

盒子模型

css学习三大重点: css 盒子模型 、 浮动 、 定位

网页布局的本质

  • 首先利用CSS设置好盒子的大小,然后摆放盒子的位置。
  • 最后把网页元素比如文字图片等等,放入盒子里面。

1. 盒子模型(Box Model)

  • 盒子模型就是把HTML页面中的布局元素看作是一个矩形的盒子,也就是一个盛装内容的容器。
  • 盒子模型由元素的内容、边框(border)、内边距(padding)、和外边距(margin)组成。
  • 盒子里面的文字和图片等元素是 内容区域
  • 盒子的厚度 我们称为为盒子的边框
  • 盒子内容与边框的距离是内边距
  • 盒子与盒子之间的距离是外边距
W3c标准盒子模型

标准 w3c 盒子模型的范围包括 margin、border、padding、content

当设置为box-sizing: content-box;时,将采用标准模式解析计算,也是默认模式;

内盒尺寸计算(元素实际大小)
  • 宽度:Element Height = content height + padding + border (Height为内容高度)
  • 高度:Element Width = content width + padding + border (Width为内容宽度)
  • 盒子的实际大小:内容的宽度和高度 + 内边距 + 边框
    在这里插入图片描述
IE盒子模型

IE 盒子模型的 content 部分包含了 border 和 pading

当设置为box-sizing: border-box时,将采用怪异模式解析计算;

2. 盒子边框(border)

属性作用
border-width定义边框粗细,单位是px
border-style边框的样式
border-color边框颜色
边框的样式:
  • none:没有边框即忽略所有边框的宽度(默认值)
  • solid:边框为单实线(最为常用的)
  • dashed:边框为虚线
  • dotted:边框为点线
边框综合设置
border : border-width || border-style || border-color 

border: 1px solid red;  没有顺序要求,通俗约定这个顺序,这种写法较多
盒子上下左右边框:

很多情况下,我们不需要指定4个边框,我们是可以单独给4个边框分别指定的。

    <style>
        /* 请给一个 200*200 的盒子,设置上边框为红色,其余边框为蓝色 */
        div {
            width: 200px;
            height: 200px;
            /* border-top: 1px solid red;
            border-bottom: 1px solid blue;
            border-left: 1px solid blue;
            border-right: 1px solid blue; */
            /* border包含四条边 */
            border: 1px solid blue;
            /* css样式的层叠性(覆盖性,就近原则) 只是层叠了 上边框 */
            border-top: 1px solid red;
        }
    </style>
上边框下边框左边框右边框
border-top-style:样式;border-bottom-style:样式;border-left-style:样式;border-right-style:样式;
border-top-width:宽度;border- bottom-width:宽度;border-left-width:宽度;border-right-width:宽度;
border-top-color:颜色;border- bottom-color:颜色;border-left-color:颜色;border-right-color:颜色;
border-top:宽度 样式 颜色;border-bottom:宽度 样式 颜色;border-left:宽度 样式 颜色;border-right:宽度 样式 颜色;
表格的细线边框:

在这里插入图片描述

  • 通过表格的cellspacing=“0”,将单元格与单元格之间的距离设置为0,
  • 但是两个单元格之间的边框会出现重叠,从而使边框变粗
  • 通过css属性:table{ border-collapse:collapse; }
    • collapse 单词是合并的意思,border-collapse: collapse;表示相邻边框合并在一起。
<style>
 table {
  width: 500px;
  height: 300px;
  border: 1px solid red;
 }
 td {
  border: 1px solid red;
  text-align: center;
 }
 table, td {
  border-collapse: collapse;  /*合并相邻边框*/
 }
</style>

2. 内边距(padding)

padding属性用于设置内边距。是指边框与内容之间的距离。
应用场景:例如新浪微博上侧导航栏,字数不一样多,如果指定盒子大小,内边距不统一,不好看,直接指定内边距,不指定小盒子宽度即可。

设置

属性作用
padding-left左内边距
padding-right右内边距
padding-top上内边距
padding-bottom下内边距

padding简写

值的个数表达意思
1个值padding:上下左右内边距;
2个值padding: 上下内边距 左右内边距 ;示例:padding:0 20px;
3个值padding:上内边距 左右内边距 下内边距;
4个值padding: 上内边距 右内边距 下内边距 左内边距 ;

当我们给盒子指定padding值之后, 发生了2件事情:

  1. 内容和边框 有了距离,添加了内边距。
  2. 盒子会变大

解决措施:通过给设置了宽高的盒子,减去相应的内边距的值,维持盒子原有的大小。

padding不影响盒子大小情况:如果盒子本身没有width/height属性,则此时padding不会撑开盒子大小。
假设子盒子指定了width: 100%;和父盒子一样宽,如果又指定了padding: 30px;则宽度会超过父盒子。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>padding不会影响盒子大小的情况</title>
    <style>   
       h1 {
           /* width: 100%; */
           height: 200px;
           background-color: pink;
           padding: 30px;
       }
       div {
           width: 300px;
           height: 100px;
           background-color: purple;
       }
       div p {
           padding: 30px;
           background-color: skyblue;
       }
    </style>
</head>
<body>
   <h1></h1>
   <div>
       <p></p>
   </div>
</body>
</html>

3. 外边距(margin)

margin属性用于设置外边距。margin就是控制盒子和盒子之间的距离

设置

属性作用
margin-left左外边距
margin-right右外边距
margin-top上外边距
margin-bottom下外边距

margin值的简写 (复合写法)代表意思 跟 padding 完全相同。

块级盒子水平居中
  • 盒子必须指定宽度(width)
  • 给左右的外边距都设置为auto

实际工作中常用这种方式进行网页布局,示例代码如下:

.header  { width: 960px; margin: 0 auto;}

常见的写法,以下下三种都可以👇👇。

  • margin-left: auto; margin-right: auto;
  • margin: auto;
  • margin: 0 auto;

文字居中和盒子居中区别👇👇

  • 盒子内的文字水平居中是 text-align: center; 而且还可以让 行内元素和行内块居中对齐
  • 块级盒子水平居中 左右margin 改为 auto

插入图片和背景图片区别👇👇

  • 插入图片我们用的最多 比如产品展示类 移动位置只能靠盒模型 padding margin
  • 背景图片我们一般用于小图标背景或者超大背景图片、背景图片,移动位置只能通过 background-position

注意:以上方法是让块级元素水平居中,行内元素是没有宽度的,行内元素或者行内块元素水平居中给其父元素添加text-align: center;即可。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>行内元素/行内块元素水平居中对齐</title>
    <style>
      .header {
          width: 900px;
          height: 200px;
          background-color: pink;
          margin: 100px auto;
          text-align: center;
      }
      /* 行内元素或者行内块元素水平居中给其父元素添加 text-align:center 即可 */
    </style>
</head>
<body>
    <div class="header">
        <span>里面的文字</span>
    </div>
    <div class="header">
        <img src="down.jpg" alt="">
    </div>
</body>
</html>

4.外边距合并

使用 margin 定义块元素的垂直外边距时,可能会出现外边距的合并。

主要有两种情况:

(1). 相邻块元素垂直外边距的合并

当上下相邻的两个块元素(兄弟关系)相遇时,如果上面的元素有下外边距 margin-bottom,下面的元素有上外边距 margin-top ,则他们之间的垂直间距不是 margin-bottom 与 margin-top 之和。取两个值中的较大者这种现象被称为相邻块元素垂直外边距的合并。

浏览器这么处理的个人理解:有点类似于css的层叠性,后来的覆盖先来的,浏览器以较大的外边距为准也是为了方便开发者,外边距本意是排开兄弟盒子,既然已经是同级相邻了,需要多少外边距肯定一开始就知道,可能后来需要改,那么只需要改其中一个,而不用管另一个。
在这里插入图片描述
「解决方案:尽量给只给一个盒子添加margin值」。

(2). 嵌套块元素垂直外边距的塌陷

对于两个嵌套关系(父子关系)的块元素,父元素有上外边距同时子元素也有上外边距,此时父元素会塌陷较大的外边距值。

浏览器这么处理的个人理解:外边距本意是排开兄弟盒子,实在没有兄弟盒子了才往body身上排。自然就会引起这个问题,如果是要和父盒子拉开距离,那么子盒子就是父盒子的内容,调整内容距离应该用内边距。
在这里插入图片描述

解决方案:

  • 可以为父元素定义上边框。
  • 可以为父元素定义上内边距。
  • 可以为父元素添加 overflow:hidden。

还有其他方法,比如浮动、固定、绝对定位的盒子不会有问题

5.4、清除内外边距

​ 网页元素很多都带有默认的内外边距,而且不同浏览器默认的也不一致。因此我们在布局前,首先要清除下网页元素的内外边距。

 * {
    padding:0;   /* 清除内边距 */
    margin:0;    /* 清除外边距 */
  }

​ 注意:行内元素为了照顾兼容性,尽量只设置左右内外边距,不要设置上下内外边距。但是转换为块级和行内块元素就可以了

盒子模型布局稳定性(width>padding>margin)

优先使用 宽度 (width) 其次 使用内边距(padding) 再次 外边距(margin)
width > padding > margin

原因:
margin 会有外边距合并 还有 ie6下面margin 加倍的bug(讨厌)所以最后使用。
padding 会影响盒子大小, 需要进行加减计算(麻烦) 其次使用。
width 没有问题(嗨皮)我们经常使用宽度剩余法 高度剩余法来做。

盒子与盒子距离最好用外边距合适。

额外知识
去掉li前面的小圆点
        li {
            /* 去掉li前面的小圆点 */
            list-style: none;
        }
QA
  1. 布局为啥用不同盒子,我只想用div?
    标签都是有语义的, 合理的地方用合理的标签。比如产品标题 就用 h, 大量文字段落就用p
  2. 为啥用那么多类名?
    类名就是给每个盒子起了一个名字,可以更好的找到这个盒子, 选取盒子更容易,后期维护也方便。
  3. 到底用 margin 还是 padding?
    大部分情况两个可以混用,两者各有优缺点,但是根据实际情况,总是有更简单的方法实现。

三、PS 基本操作

​ 因为网页美工大部分效果图都是利用 PS(Photoshop)来做的,所以以后我们大部分切图工作都是在 PS 里面完成。

​ 部分操作:

  • 文件→打开 :可以打开我们要测量的图片
  • Ctrl+R:可以打开标尺,或者 视图→标尺
  • 右击标尺,把里面的单位改为像素
  • Ctrl+ 加号(+)可以放大视图, Ctrl+ 减号(-)可以缩小视图
  • 按住空格键,鼠标可以变成小手,拖动 PS 视图
  • 用选区拖动 可以测量大小
  • Ctrl+ D 可以取消选区,或者在旁边空白处点击一下也可以取消选区
    在这里插入图片描述
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值