初识HTML5&CSS3

一、HTML基础标签

1.HTML简介

超文本标记语言(英语:HyperText Markup Language,简称:HTML)是一种用于创建网页的标准标记语言

标记语言是一套标记标签

HTML 使用标记标签来描述网页

HTML 文档包含了HTML 标签文本内容

HTML 运行在浏览器上,由浏览器来解析

HTML文档也叫做 web 页面

文档的后缀名:xxx.html 或 xxx.htm

2.HTML标签

HTML 标记标签通常被称为 HTML 标签 (HTML tag)

HTML 标签是由尖括号包围的关键词,比如 <html>

HTML 标签通常是成对出现的,比如 <b> 和</b>

标签对中的第一个标签是开始标签,第二个标签是结束标签

开始和结束标签也被称为开放标签闭合标签

3.HTML基础标签

html

html是网页的根标签,网页的所有内容,都必须要写在该标签里面

head

head是头部标签,用于导入外部的资源信息和描述网页自身信息

title

title是网页自身的标题标签,它里面的内容会在网页的浏览器的选项卡上显示

body

body是主体标签,网页中能看到到所有内容,都必须要写在该标签里面

<!DOCTYPE html>

文档声明,是告诉浏览器采用什么标准去解析下面的网页,这里表示html5的标准

如果没有文档声明标签,浏览器会根据网页中具体的标签去判断使用什么标准

其他标准:

HTML 4.01

<!DOCTYPEHTMLPUBLIC"-//W3C//DTD HTML 4.01 Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">

XHTML 1.0

<!DOCTYPEhtmlPUBLIC"-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

meta

meta标签提供关于HTML文档的元数据。元数据不会显示在页面上,但是对于机器是可读的。它可用于浏览器(如何显示内容或重新加载页面),搜索引擎(关键词),或其他 web 服务

meta标签是单标签,不需要闭合标签,规范写法,单标签需要自闭合

声明编码:

utf-8 包含全世界所有国家需要用到的字符

gb2312 包含全部中文字符

<metacharset='utf-8'/>

页面关键词:

<metaname="keywords"content="前端,web前端"/>

页面描述:

<metaname="description"content="如何学好前端"/>

页面重定向和刷新:

content内的数字代表时间(秒),既多少时间后刷新。如果加url,则会重定向到指定网页

<metahttp-equiv="refresh"content="30;url="/>

移动设备:

如果不是响应式网站,不要使用initial-scale或者禁用缩放

大部分4.7-5寸设备的viewport宽设为360px;5.5寸设备设为400px;iphone6设为375px;ipone6 plus设为414px

<metaname="viewport"content="width=device-width, initial-scale=1.0,maximum-scale=1.0, user-scalable=no"/><!-- `width=device-width` 会导致 iPhone 5 添加到主屏后以 WebApp 全屏模式打开页面时出现黑边  -->

width:宽度(数值 / device-width)(范围从200 到10,000,默认为980 像素)

height:高度(数值 / device-height)(范围从223 到10,000)

initial-scale:初始的缩放比例 (范围从>0 到10)

minimum-scale:允许用户缩放到的最小比例

maximum-scale:允许用户缩放到的最大比例

user-scalable:用户是否可以手动缩 (no,yes)

注意,很多人使用initial-scale=1到非响应式网站上,这会让网站以100%宽度渲染,用户需要手动移动页面或者缩放。如果和initial-scale=1同时使用user-scalable=no或maximum-scale=1,则用户将不能放大/缩小网页来看到全部的内容

<link/>

导入外部资源,比如:网页选项卡图标外部样式

<linkrel="icon"href="favicon.ico">

h1~h6

h1~h6是网页的内容标题标签,h1最大,h6最小。标题标签的特点是:字体会加粗

p

p标签是段落标签,用于描述一段内容

hr

hr是水平线标签,用于对网页中的内容进行分隔

br

在网页中,无论打多少空格,或者换多少次行,默认都只是一个空格

如果需要手动换行,需要使用br标签

strong

strong是加粗标签,用于突出一段内容里面的部分信息

em

em是倾斜标签,也用于突出一段内容里面的部分信息

特殊符号

&nbsp;      空格

&lt;             小于号

&gt;            大于号

&quot;         双引号

&copy;        版权符号

img

img是图片标签,src属性设置图片的地址,地址可以是本地地址,也可以是网络地址

title属性设置鼠标悬停提示信息,alt属性设置图片的替代文字,当图片无法显示时,显示对应的文字

width属性设置图片宽度,height属性设置图片高度,如果只设置了其中一个属性,另一个属性会等比缩放

a

超链接标签,根据链接类型可以分为:页面间链接锚链接功能性链接

1.页面间链接:

href属性设置链接的地址,可以是本地地址,也可以是网络地址

target属性设置目标窗口打开的位置,属性值_self替换自身窗口,_blank是打开新窗口

<a href="./index06.html"target="_self">替换自己</a>

<a href="./index06.html"target="_blank">打开新窗口</a>

2.锚链接:

用于当前页面的跳转,从页面的某个区域,跳转到另一个区域

通常需要两个a标签,一个a标签通过name属性设置锚标记,另一个a标签通过href属性跳转到对应的锚标记处

注意:href属性值需要加一个#号

如果需要跨页面,在href属性中,显示设置地址,在地址的后面在设置对应的锚标记

<a href="#bj">北京</a>

<!-- 这里的a标签,只是做一个锚标记,通过name属性设置标记名 -->

<a name="bj"></a>

3.功能性链接:

利用超链接打开本地的应用

<a href="mailto:123456789@qq.com">发送邮件</a>

<a target="_blank"href="http://wpa.qq.com/msgrd?v=3&uin=123456789&site=qq&menu=yes">打开QQ</a>

div

div是分区标签,是一个块级标签,通常用于网页的布局

span

span是范围标签,是一个行级标签,通常用于突出显示段落中的部分内容

4.标签分类

所有的标签可以分为两类:块级标签和行级标签(内联标签)

块级标签:该元素独占一行(h2,p)

行级标签:按行显示,一行不够放,才会自动换行(a,strong,em,img)

注意:通常情况下,行级标签要放在块级标签里面使用

注意:p标签不能嵌套p标签

二、列表、表格、表单

1.有序列表和无序列表

ol是有序列表标签,它里面的列表项是有序号

ul是无序列表标签,它里面的列表项是没有序列的,但是有符号

li 是列表项标签

列表可以嵌套定义

通过设置ol的type属性值,可以改变序号类型,可以设置属性值有:A,a,I,i,1

ul标签通过type属性,也可以设置符号类型:属性值有:disc,circle,square

2.定义列表标签

dl是定义列表标签

dt的定义列表的标题标签

dd是定义列表的描述标签,用来描述dt

可以用多个dd去描述一个dt

一个dl可以只描述一个dt,也可以描述多个dt

一般图文布局的结构会使用定义列表标签

3.表格标签

table是表格标签,通过border属性设置表格的边框,width属性设置宽度,height属性设置高度

设置表格的属性align="center",将整个表格居中

tr是行标签

设置tr的align属性,控制的是tr里面的所有td的水平对齐方式

td是列标签

td设置align属性,只是对当前td设置水平对齐方式

colspan属性,用于单元格跨列

rowspan属性,用于单元格跨行

如果表格里面的单元格需要跨列或者跨行:

先将完整的表格画好

然后做跨列

最后做跨行

4.表格的完整结构

表格根据结构划分:thead是表格的头部,tbody是表格的主体,tfoot是表格的尾部

caption是表格的标题标签

td是普通列,th是表头列,th里面的内容默认会加粗并且居中

5.表单标签

form表单标签,表单的作用是:接收用户输入的数据,并向服务器发送

method属性设置表单的提交方式:GET和POST (POST比GET更安全)

action属性设置表单的提交地址,比如:http://192.168.112.55:8080/address/add

6.表单里面的常用元素

form是表单标签,所有的表单元素,必须要放到form标签里面,才能提交到服务器

如果表单中使用了文件域,表单标签需要添加一个enctype="multipart/form-data"属性

input标签是表单的元素,绝大多数表单元素都是使用input标签,通过type属性设置元素的类型

type="text"是文本框,size属性设置初始长度,maxlength属性设最大输入长度,name属性设置表单元素的名称

type="password"是密码框

type="radio"是单选框,注意:一组单选框,必须要设置相同的name属性值,value属性设置表单元素保存的值,

checked属性设置默认选中,该属性的属性值也是checked。

注意:在html中如果属性值跟属性名相同,可以省略属性值

type="checkbox"是复选框,也可以使用checked属性

type="file"是文件域,该标签用于选择文件

type="button"是普通按钮

type="submit"是提交按钮,用于将表单里面的数据向服务器提交,disabled属性设置表单元素禁用

type="reset"是重置按钮,用于清空表单里面的填写内容

type="image"是图片提交按钮,它不需要通过value属性设置文本,但是需要通过src属性设置一张图片

type="hidden"是隐藏域,用于在网页中隐藏信息。在实际开发中,隐藏域里面的信息是需要加密存储的

select标签是下拉框,option是下拉框的选项标签,value属性设置每个选项的值,

注意:值可能跟显示的文本不一样,selected属性设置默认选中

textarea标签是文本域,其实就是多行文本框,rows属性设置行数,cols属性设置每行列数

readonly属性表示只读

7.html5新增表单元素

type="number"是数字文本框,min设置最小值,max设置最大值,step设置增量值

type="range"是滑块,min,max,step用法同number

type="url"是网址文本框,输入的内容必须以ftp: 或者 http: 或者 https: 开头

type="email"是邮箱文本框,输入的内容必须包含@字符

type="search"其实就是文本框,只是专门用于做搜索框用,输入内容后,带有清空内容的小按钮

<button type="submit">提交按钮</button>

<button type="reset">重置按钮</button>

<button type="button">普通按钮</button>

新增属性:

placeholder属性设置文本框里面的提示内容,当在文本框中输入真正的内容时,会自动消失

required属性给文本框,添加非空验证

pattern属性用于给文本框,添加正则表达式验证

三、初始样式

1.行内样式表

通过在标签中使用style属性的方式,可以给标签添加行内样式

在实际开发中,不推荐使用行内样式,因为行内样式不方便样式的复用

行内样式,违反了内容与表现分离的原则,网页后期改版会变复杂

更关键的是,这样的网页不利于搜索引擎搜索

2.内部样式表

在head标签中通过style标签,定义内部样式。style标签可以通过type属性明确里面的样式类型,type属性可以省略

内部样式表:可以做到当前页面的样式复用,但是不能做到多页面样式的复用,内容与表现的分离不够彻底

在style标签里面,通过定义选择器的方式,定义样式

下面的样式就是根据p标签的名称定义选择器,给p标签添加样式:

p{font-size:30px;color:red;}

3.外部样式表

通过link标签,引入外部样式文件,href属性设置样式文件的路径

注意:必须设置rel属性的属性值为stylesheet。告诉浏览器引入外部资源是样式表资源

如果有多个页面需要该样式,直接引入,方便多页面样式的复用

网页的内容和样式彻底分离,这样的网页更利用搜索引擎搜索

<link rel="stylesheet" href="./css/style.css">

引入外部样式文件的第二种方式,在style标签中,通过@import方式导入指定的样式文件

<style>@import url('./css/style02.css');

4.样式的优先级

外部样式和内部样式的优先级采用:就近原则,后引入的,优先级更高

行内样式的优先级最高

5.选择器

1.基本选择器

标签选择器:以标签的名称作为选择器的名称,对所有该标签添加样式

类选择器:选择器的名称是自定义的,必须以.符号开头。在标签中,通过class属性调用具体的类选择器样式,在标签中使用时,不需要加.号

id选择器:选择器的名称也是自定义的,必须以#符号开头。在标签中,通过id属性调用具体的id选择器样式,在标签中使用时,不需要加#号

注意:在网页中,标签的id属性值,通常是不能重复的。id选择器的优先级更高

2.基本选择器的优先级

基本选择器的优先级:id选择器 > 类选择器 > 标签选择器

注意: !important优先级最高

3.层次选择器

后代选择器,方式是:A B{}。对A里面所有B添加样式

子选择器,方式是:A>B{}。 对A里面的所有第一级的B添加样式

相邻兄弟选择器,方式是:A+B{},B必须是A相邻的下一个元素

通用兄弟选择器,方式是:A~B{},对A下面的所有的B元素添加样式

4.属性选择器

属性选择器,方式是:[属性名]{},通常会配合其他选择器一起使用,比如:li[属性名],只针对li标签

属性选择器,可以根据属性值,精确的对某些标签添加样式

$= 表示以指定的属性值结尾

^= 表示以指定的属性值开头

*= 表示属性值包含指定的内容

实际案例:给以.png结尾的图片,设置大小

img[src$='.png']{width:100px;height:100px;}

5.交集选择器

交集选择器,方式是:选择器A选择器B{},同时满足A和B的元素,添加样式

a.red{color:red}

6.并集选择器

并集选择器,方式是:A,B,C{},给多个选择器设置相同的样式

案例:.header里面的.nav 和 .centent里面的p 和 #two上面的.three,采用相同的样式

.header.nav,.cententp,#two.three{font-size:20px;color:red;}

四、基础样式

1.字体样式

font-size 设置字体的大小

单位:px是像素

font-family 设置字体的类型

font-family 可以设置中文字体类型,也可以设置英文字体类型,如果需要同时设置英文字体类型和中文字体类型,先设置英文,再设置中文

font-family:'Courier New','幼圆'

font-weight 设置字体的粗细,属性值bold表示加粗

font-style 设置字体的风格,属性值italic表示倾斜

font是字体的缩写属性,可以同时设置:风格 加粗 大小 类型

风格和加粗的顺序可以变化,也可以省略,最后两个属性值必须是大小类型

特殊用法:20px是字体大小,40px是行高

font:20px/40px'楷体'

2.文本样式

color 是文本颜色

颜色值可以是英文单词

颜色值可以是十六进制颜色值,方式是:#红绿蓝

下面属性值里面的ff其实是十六进制的255

color:#ff0000;

颜色值可以是十进制颜色值,方式是:rgb(红,绿,蓝)

color:rgb(255,0,0);

rgba(红,绿,蓝,透明度),注意:透明度的取值范围是:0-1

color:rgba(255,0,0,0.5);

十六进制颜色值,加透明度的方式是:#红绿蓝透明度。注意:这里的透明度的取值范围是0-255

color:#ff000055

text-align 是文本对齐方式,属性值包括:left(默认值),center,right

text-indent 是首行缩进,首行通常需要缩进两个字符,所有属性值单位通常使用em或者rem

一个em大小就是当前元素字体的大小尺寸。

一个rem的大小默认是网页字体的默认大小(16px)

line-height 是行高

text-decoration 是文本装饰,属性值包括:underline(下划线),overLine(上划线),line-through(删除线),none(没有装饰)

可以通过text-decoration属性,

text-decoration: none;

去掉超链接的默认下划线

letter-spacing 是字符间距

word-spacing 是单词间距

3.超链接样式

a:link 表示未点击的样式

a:visited 表示点击过后的样式

a:hover 表示鼠标悬停样式

a:active 表示点击未释放样式

注意:顺序必须是:a:link a:visited a:hover a:active

一般情况下,我们会先给a元素设置统一的样式,再添加一个a:hover

4.列表样式

list-style-type 设置列表样式,属性值none,表示无样式

其它属性值,包括:disc(实心圆) circle(空心圆) square(方块) decimal(数字)

所以,所谓有序列表和无需列表,只是默认的列表样式值不同

list-style-image 设置列表的样式为图标

list-style-position 设置列表样式的位置,属性值包括:inside 和 outside(默认值),inside属性值,列表会往里缩进一个tab符

list-style 是缩写属性,既可以设置列表符号类型,也可以设置列表图标

5.背景样式

background-color 背景颜色

background-image 背景图片

background-repeat 背景图片的平铺方式,

属性值包括:no-repeat(不平铺) repeat(平铺) repeat-x(X轴平铺) repeat-y(Y轴平铺)

background-position 背景图片的位置,

可以通过:left right top bottom center 这些方位值设背景图片的具体位置,

也可以通过:具体的数字设置X轴和Y轴的位置,

还可以通过:百分比设置X轴和Y轴的位置,

无论是给具体的数字,还是给具体的百分比,如果只传一个值,X轴和Y轴的位置相同

background-size 属性设置背景图片的大小,

属性值contain,表示:等比拉伸,直到跟任意一边与容器边框重叠,

属性值cover,表示:等比拉伸,直到跟所有边与容器边框重叠,

可以设置固定的大小,一般不推荐,因为会使图片变形,

属性值也可以设置百分比

background背景缩写属性,可以同时设置背景颜色背景图片平铺方式位置

各属性值,没有严格的顺序

如果要加背景图片的大小,方式是:颜色 图片 平铺方式 位置 / 背景图片大小

background: red url(./img/zhl.jpg) no-repeat center / 300px 300px;

6.背景渐变

linear-gradient()函数,用于设置背景的线性渐变

该函数的第一个参数值是渐变的方向,后面的参数值是渐变的颜色

background: linear-gradient(to left top,red,blue,green,purple);

radial-gradient()函数,用于设置背景的镜像渐变

该函数不需要传渐变方向,直接传渐变的颜色,从中间向外渐变

background: radial-gradient(red,blue,green);

7.文本垂直居中

如果只有一行文本内容,可以通过设置line-height:height(行高=高度)的方式,设置单行文本垂直居中

8.文本阴影

text-shadow 属性设置文本阴影

属性值分别是:X轴偏移量 Y轴偏移量 阴影的模糊半径 阴影颜色

9.图片对齐方式

图片的vertical-align样式,可以设置图片两端文本相对于图片的对齐方式

属性值包括了:top bottom middle

五、盒子模型

1.什么是盒子模型

网页里面的每一个标签,都可以当做是一个盒子,该盒子是用来放内容的

通过:宽高,内边距,边框,外边距定义盒子

2.边框

每条边框可以通过三个属性设置,分别设置:边框宽度 边框颜色 边框类型

边框类型solid,表示实线

边框类型double,表示双实线

边框类型dashed,表示虚线

边框类型dotted,表示点线

通常情况下,盒子的四条边框的样式应该是统一的,可以通过下面的三个属性去统一设置

border:10px tomato dotted;

去掉文本框的轮廓线

outline:none;

3.内边距

可以分别设置盒子四个方向的内边距

padding-top:20px;

padding-right:40px;

padding-bottom:60px;

padding-left:80px;

padding是缩写属性,可以分别设置:上 右 下 左 四条边的内边距。(顺序是顺时针)

padding:20px 40px 60px 80px;

padding如果只设置3个属性值,分别是:上 右 下,左边采用右边的值

padding:20px 40px 60px;

padding如果只设置2个属性值,分别是:上 右,左边采用右边的值,下面采用上面的值

padding:20px40px;

padding如果只设置1个属性值,表示上 右 下 左采用相同的内边距

padding:20px;

4.外边距

外边距是设置盒子与盒子间距

margin-top:50px;

margin-right:50px;

margin-bottom:100px;

margin-left:100px;

注意:上下两个盒子的间距采用上面盒子的底边距和下面盒子的上边距的最大值

margin的缩写属性,用法同padding一样

5.盒子居中

因为网页中的很多标签,都有默认的样式,在实际开发中,我们又不需要这些默认的样式,

所以,可以使用通用选择器,去掉这些默认样式

*{

    /* 去掉外边距 */margin:0;

    /* 去掉内边距 */padding:0;

    /* 去掉列表符号 */list-style:none;

    /* 去掉轮廓线 */outline:none;

    /* 去掉下划线 */text-decoration:none;

}

如果设置盒子居中显示。属性值auto,表示自动,左右外边距的属性值为auto,会自动平分剩余的空间

margin:0 auto;

6.盒子尺寸

width和height属性设盒子内容区域的大小

border,padding,margin 会增长盒子的整体尺寸

盒子的实际宽度= width + border-left + border-right + padding-left + padding-right + margin-left + margin-right

box-sizing属性设置盒子的类型,默认值是content-box,是内容盒子,表示width和height的空间全部给内容

属性值border-box,是边框盒子,盒子的边框和内边距产生的空间从width和height里面扣除

7.display属性

块级元素:特点是独占一行,可以识别宽高属性

一个块级元素的实际宽度 = width + border-left/right + padding-left/right + margin-left/right

margin-right属性的默认值是auto,所以,剩余的空间会给margin-right

行级元素:特点是按行显示,一行不够放,会自动换行,不识别宽高属性,它的实际大小还有内容决定

通过display属性,可以设置标签的显示方式,inline表示行内元素,block表示块级元素,none表示不显示

inline-block表示行内块元素,既有块级元素可以识别宽高的特点,又有行内元素在一行显示的特点

8.盒子阴影

盒子阴影:属性值分别是:X轴偏移量 Y轴偏移量 模糊半径 阴影颜色

box-shadow:10px 10px 5px blue;

第一个属性值设置为inset,表示内阴影

box-shadow:inset 0px 0px 30px blue;

9.圆角边框

分别设置4个角的圆角

border-top-left-radius:20px;

border-top-right-radius:40px;

border-bottom-right-radius:60px;

border-bottom-left-radius:80px;

一个属性值是横向宽度,第二个属性值是纵向宽度,这样的圆角就是椭圆圆角

border-top-left-radius:20px 40px;

border-top-right-radius:40px 60px;

border-bottom-right-radius:60px 80px;

border-bottom-left-radius:80px 100px;

border-radius是缩写属性,可以同时设置:左上 右上 右下 左下,四个角的圆角

border-radius:20px 40px 60px 80px;

四个角的圆角都设置为50%,就是正圆

border-radius: 50%;

五、浮动

1.float

浮动样式主要用于对块元素的布局

元素一旦浮动起来,就会脱离标准文档流

float属性设置浮动,属性值包括left(左浮动),right(右浮动),none(不浮动)

2.clear

用于清除浮动。属性值包括:left(清除左浮动),right(清除右浮动),both(清除全部浮动)

3.解决父级边框塌陷

方式一:

在标准文档流中,父级如果不指定高度,高度由子级撑开。

如果子级浮动,父级的边框就会塌陷,第一种解决的方法是:给父级一个明确的高度。

方式二:

在父级的最下面,添加一个不浮动的元素,并清除前面的浮动空间。

方式三:

通过伪元素样式在父级的下面添加块级元素,再利用该块级元素清除前面的浮动,原理根方法2一样。

::after表示在指定的父级的下面,添加元素

::before表示在指定的父级的上面,添加元素

.parent::after{

    /* content属性里面设置添加的元素里面的内容 */content:'';

    /* 下面是设置该元素的样式 */display:block;

    clear:both;

}

方式四:

给父级添加一个overflow属性,属性值是非visible

4.overflow

overflow属性,用于设置溢出处理

属性值包括:

visible(溢出部分显示,是默认值)

hidden(溢出部分隐藏)

scroll(溢出部分,通过滚动条查看),如果内容不溢出,还是会出现滚动条的区域

auto(自动,如果内容溢出,出现滚动条;没有溢出,不会出现滚动条区域)

5.overflow配合锚链接

overflow配合锚链接的使用,可以增长一个盒子的实际使用空间

id属性值可以作为锚链接的锚标记使用

6.文本溢出处理

white-space 属性设置空白处理,属性值nowrap,表示设置文本不换行,属性值pre,表示保留空格

overflow 属性是溢出处理,属性值hidden表示溢出部分隐藏

text-overflow 属性设置文本溢出处理,属性值ellipsis表示文本溢出部分显示...

注意:上面的三个属性值缺一不可

overflow:hidden;

white-space:nowrap;

text-overflow:ellipsis;

7 多行文本溢出处理

display:-webkit-box;

overflow:hidden;

text-overflow:ellipsis;

word-break:break-all;

-webkit-box-orient:vertical;//子元素应该被水平或垂直排列

-webkit-line-clamp:3;//3行后显示省略号

六、定位

1.static

position 是定位属性,属性值包括:static(不定位,默认值)

2.relative

relative(相对定位),是相对于自己重新定位,通过top,bottom,left,right属性控制定位的偏移量

3.absolute

absolute(绝对定位)。绝对定位是根据离它最近的父级定位元素进行定位

如果它的父级中,没有定位元素,就根据浏览器的视口来定位

注意:绝对定位元素,会脱离标准文档流,所以,它下面的元素会去抢占它原来的位置

通常情况下:一个父容器里的子元素,如果要进行调整位置

父容器先设置为相对定位,并且不设置偏移量,子元素再设置为绝对定位,

这样,子元素就可以在该父元素中精细调整了

4.fixed

fixed(固定定位)。就是根据浏览器的视口进行定位

并且定位后的位置不会随着浏览器滚动条的滚动而消失

5.z-index

元素定位后,默认情况下,后面的元素会盖住签名的元素

通过z-index属性,可以修改定位元素的层叠顺序

值越小越靠下,值越大越靠上,可以设置负数,默认值0

6.盒子水平和垂直方向居中

/* 子级设置为绝对定位 */

position:absolute;

left:0;

right:0;

top:0;

bottom:0;

margin:auto;

非定位元素的实际宽度 = width + border-left + border-right + padding-left + padding-right + margin-left + margin-right

定位元素的实际宽度 = width + border-left + border-right + padding-left + padding-right + margin-left + margin-right + left + right

7.透明度

opacity属性,设置透明度,注意:是设置整个元素的透明度

取值范围是:0-1,0是全透明,1是不透明

8.背景样式补充

设置背景颜色 background-color

设置背景图片 background-image

设置背景平铺方式 background-repeat,默认是X轴和Y轴方向都平铺

设置背景图片的位置 background-position

设置背景图片的大小 background-size

设置背景的填充区域 background-clip

属性值有:

border-box 到边框,默认值

padding-box 到内填充

content-box 到内容

background-origin 只能设置背景图片的填充区域,不能控制背景颜色

background-attachment 设置背景图片的定位方式:

设置属性值为fixed,表示固定背景图片

在缩写属性中,如果同时设置了背景位置和背景大小,方式是:位置 / 大小

background:fixed url() content-box 40px 40px / 600px 400px;

七、补充内容

1.结构伪类选择器:

:first-child 表示指定标签的第一个

注意:这里ul里面的第一个元素如果不是li,该样式失效

ul li:first-child{color:red;}

:last-child 表示指定标签的最后一个

注意:这里ul里面的最后一个元素如果不是li,该样式失效

ul li:last-child{color:green;}

:nth-child(n) 表示指定标签的第n个

odd表示所有的奇数行(也可以用2n-1),even表示所有的偶数行(也可以用2n)

:first-of-type和:first-child的区别是:

:first-child:计算索引时,统计的是所有的子元素

:first-of-type 计算索引时,只统计指定的子元素

:last-of-type和:last-child的区别同上

:nth-of-type和:nth-child的区别同上

2.内嵌框架

iframe 是内嵌框架标签,用于在当前网页中,嵌入另一个完整的网页,通过src属性设置目标网页的地址

frameborder属性设置边框,属性值包括0和1

scrolling属性设置是否显示滚动条,属性值包括no和 yes 和 auto

3.video

video标签,用于播放视频,src属性设置视频路径,controls属性显示控件按钮,autoplay属性设置自动播放,loop属性设置循环播放

通过source子标签,给video标签添加视频路径,好处是,该方式可以同时添加多个视频路径

由于不同浏览器对视频格式的兼容性,存在差异,所以,会导致,指定格式的视频在部分浏览器中无法播放

通常情况下,如果在网页中需要播放视频,会将同一个视频转成多种格式,通过source标签引入

浏览器会挨个加载source标签引入的视频,直到找到一个可以播放的格式

video标签里面的写的其他标签,在浏览器不识别video标签时显示

4.audio

audio是音频标签,用于播放音频,用法根video一样

5.HTML5结构标签

过去,我们在布局网页的时候,全部采用div标签,给div标签定义不同的id名称,

用该id名称去表示它所处的区域是网页的哪一个部分

现在,HTML5给我们新推出了一些,专门用于布局的结构标签:

header 头部

nav 导航

main 主体

aside 侧边栏

section 独立区域(网页中有多个独立区域时,用section)

article 独立内容(网页中只有一个独立区域时,用article)

footer 尾部

fieldset标签,用于设置一个分组区域,通过legend子标签设置分组标题。

八、动画

1.css3-过渡

transition 过渡属性

过渡:css从一种状态变化到另一种状态的过程。

transition-property 设置哪些属性,需要过渡效果,可以传多个过渡的属性,使用逗号隔开。

例如: transition-property: background-color,width,

属性值设置为all,表示过渡全部属性。

transition-duration 设置过渡的时间,就是完成整个效果,需要花费的时间,

单位可以是秒(s)或者毫秒(ms)。

transition-delay 设置过渡之前的等待时间,单位同transition-duration

transition-timing-function 设置过渡的动作函数:

默认值是 ease 表示先快速再慢速

linear 表示匀速

ease-in 表示加速

ease-out 表示减速

ease-in-out 表示先加速再减速

transition是过渡的缩写属性,四个属性值的顺序没有要求,但是如果设置了两个时间,第一个是过渡时间,第二个过渡等待时间

2.css3-动画

animation-name 指定动画的名称(指定一个动画的关键帧名称,就是动画的规则)

animation-duration 指定动画的时间(完成该动画需要多少时间

animation-delay 动画的延迟播放时间

animation-timing-function 动画的动作函数,ease linear ease-in ease-out ease-in-out

animation-iteration-count 设置动画的播放次数 属性值可以给具体的次数,如果设置属性值为infinite,表示无限次数

animation-play-state 表示播放状态,默认值是running(播放) paused(暂停)

animation-direction 表示动画的方向,属性值包括:

normal(正向) reverse(反向) alternate(正反方向重复运动) alternate-reverse(反正方向重复运动)

animation-fill-mode 表示填充模式,其实就是动画结束后,元素的回到什么位置,属性值包括:

backwards(回到原点位置),在开始动画之前,等待的时间在开始动画处等待,

forwards(停在结束位置),在开始动画之前,等待的时间在原点位置处等待,

both(综合了上面两个属性的特点),在开始动画处等待,在动画结束处停止,

animation是缩写属性,具体的属性值,没有顺序要求,如果同时设置动画时间和等待时间,第一个是动画时间,第二个是等待时间

3.关键帧

定义动画的关键帧,关键帧就是动画的规则,在css中,一个动画最多可以拆分成100份

@keyframesmove{

    /* from 是动画的起始位置 */

    from{

        left: 0;

    }

    /* to  是动画的结束位置*/

    to{

        left: 500px

    }

}

定义动画的关键帧,将动画的规则,拆分成多组

@keyframesmove2{0%{left:100px;top:0;}25%{left:500px;top:0;}50%{left:500px;top:500px}75%{left:0;top:500px;}100%{left:0;top:100px;}}

4.css3-变形

transform 是css的变形属性,通过变形函数,设置具体的变形方式

scale()变形函数,设置元素缩放

translate()变形函数,设置元素平移,该函数如果只传一个参数,表示X轴方向平移,如果传两个参数,第二个参数是Y轴方向平移

rotate()变形函数,设置元素旋转。属性值的单位是deg(度数),也可以是turn(圈),属性值,正数是顺时针,负数是逆时针

skew()变形函数,设置元素倾斜。该函数如果只传一个参数,表示X轴方向倾斜度数,如果传两个参数,第二个参数是Y轴方向倾斜度数

5.动作函数补充

transition-timing-function 设置动作函数

属性值包括:ease linear ease-in ease-out ease-in-out

动作函数的取值,除了一些常规的属性值,还可以里贝塞尔曲线函数,定义特殊规则的动作

transition-timing-function:cubic-bezier(.22,1.52,.42,-0.72);

通过steps() 函数,可以将一个动作分解成多次运行

animation:move12sinfinitesteps(4)

6.3D变形

perspective 属性设置浏览器的视距:就是告诉浏览器平移到眼睛的距离是多少,一般范围我们会控制在600px-1200px,常用值为800px

body{height:600px;border:1pxsolidgreen;perspective:800px;}

translateX() 是X轴方向平移

translateY() 是Y轴方向平移

translateZ() 是Z轴方向平移

rotate() 默认是久Z轴方向旋转

rotateZ() 是Z轴方向旋转

rotateX() 是X轴方向旋转

rotateY() 是Y轴方向旋转

3d变形样式 transform-style: preserve-3d;

transform-style: preserve-3d;

transform: rotateY(45deg) rotateZ(-45deg);

animation: love 4s infinite alternate;

visibility属性,用于设置元素的显示方式,属性值包括:hidden(隐藏),visible(显示)

backface-visibility属性,用于设置元素的背面颜色方式

backface-visibility: hidden,表示背面隐藏

九、iconfont

1.字体图标

<!--本地引入--><linkrel="stylesheet"href="./iconfont/iconfont.css"><!--在线使用iconfont字体图标--><linkrel="stylesheet"href="//at.alicdn.com/t/font_2502001_xzq5sve8osd.css"><!--i 标签 专门用于定义字体图标--><iclass="iconfont icon-gouwuche"></i>

2.自定义字体类型

@font-face{/* 设置字体类型名称 */font-family:gjm;/* 设置字体类型文件的路径 */src:url(./font/郭敬明字体.ttf);}div{font-size:50px;font-family:gjm;}

3.CSS绘制三角形

/* 保留上边框,下边框的宽度设为0 */.a{border-color:transparent;border-top-color:red;border-width:50px50px050px;}/* 保留右边框,左边框的宽度设为0 */.b{border-color:transparent;border-right-color:blue;border-width:50px50px50px0;}/* 保留下边框,上边框的宽度设为0 */.c{border-color:transparent;border-bottom-color:green;border-width:050px50px50px;}/* 保留左边框,右边框的宽度设为0 */.d{border-color:transparent;border-left-color:orange;border-width:50px050px50px;}

十、弹性布局

1.弹性盒子

display属性,设置元素的类型,属性值包括:none(不显示),inline(行内元素),block(块级元素),inline-block(行内块元素)

设置display: flex,该盒子就成为了弹性盒子,一旦给一个盒子设置为了弹性盒子,它里面的子元素默认就会横向排列

flex-direction属性 设置子元素的排列方向,属性值包括:row(横向) column(纵向) row-reverse(横向反向) column-reverse(纵向方向)

2.子元素的对齐方式

主轴的排列方式,通过justify-content属性控制

属性值包括:flex-start(开始处对齐) flex-end(结束处对齐) center(居中对齐) space-between(平均分布,开始和结束处顶格),space-around(平均分布,两边留有一半的间隔空间) space-evenly(平均分布,每个元素两端的间隔相等)

辅轴的排列方式,通过align-items属性控制

属性值包括: flex-start(开始处对齐) flex-end(结束处对齐) center(居中对齐) baseline(首行文本的基线对齐) stretch(拉伸对齐)

注意:主轴不一定是横向,排列方向如果是横向,主轴是横向;排列方向如果是纵向,主轴就是纵向

3.子元素的换行方式

flex-wrap属性,设置弹性盒子内,子元素的换行方式

属性值包括: nowrap(不换行) wrap(换行) wrap-reverse(反向换行)

align-content属性,设置子元素换行后,每行元素在辅轴上的对齐方式

注意:一旦设置了align-content,align-items属性就失效

align-content的属性值包括:flex-start(开始处对齐) flex-end(结束处对齐) center(居中对齐) space-between(平均分布,开始和结束处顶格),space-around(平均分布,两边留有一半的间隔空间) space-evenly(平均分布,每个元素两端的间隔相等)

总结:不换行,辅轴上的对齐方式用align-items,换行后,辅轴上的对齐方式用 align-content。

4.子元素order属性

order属性,用于设置子元素的排列顺序,默认值是1,值越小越靠前,值越大越靠后

5.子元素margin属性

子元素通过margin属性,可以抢占父级的剩余空间作为自己的外边距

6.子元素align-self属性

align-items属性设置所有弹性子元素在辅轴上的对齐方式

align-self属性,用于设置弹性子元素自身在 辅轴 方向上的对齐方式

属性值包括:flex-start,flex-end,center,baseline,stretch

7.子元素flex属性

flex属性用于指定弹性子元素如何分配空间

.b为flex:5,.c为flex: 1 表示剩余的空间,b占5份,c占1份

十一、移动端

1.什么是像素

什么是像素:就是一个发光点

我们在编写网页的时候,所说的像素,其实是css像素

比如我们的显示器的分辨率是1920*1080,这里的1920是物理像素

一般情况下,一个css像素对应一个物理像素

如果浏览器放大两倍,此时就会是一个css像素对应两个物理像素

在移动端,通常的做法就是一个css像素对应多个物理像素,一般采用的是两个或者三个物理像素

由于我们的显示器,默认是放大125%,所有,在默认浏览器中css像素跟物理像素的比例是 1 : 1.25。1个css像素的宽度 对应 1.25个物理像素的宽度

2.移动端网页

在移动端:iphone6手机的分辨率:750*1334(物理像素)

在iphone6中 css像素是375*667,所以,css像素和物理像素的比例是 1 : 2

iphone6Plus手机的分辨率:828*1472

在iphone6Plus中 css像素是414*736,所以,css像素和物理像素的比例是 1 : 2

100vw就表示显示屏全屏宽度,100vh就是表示显示屏全屏高度

在iphone6中 100vw = 375px

1px = 0.266666vw

2.66666vw就相当于10px

5.33333vw就相当于20px

因为字体的最小单位是12px,所以我们将上面的比例再 * 2

font-size: 5.33333vw

em是当前元素字体大小单位

rem是网页根元素字体大小单位

默认情况下,1rem=16px,但是这里的rem已经被我们重新定义过了

1rem=5.33333vw 在iphone6中是20px

html{font-size:5.33333vw}.a{width:100vw;height:100px;background-color:red;}.b{width:5rem;height:5rem;background-color:green;font-size:1rem;}

3.视口

name="viewport"就是设置视口

设置width属性值为device-width,采用设备的宽度

initial-scale=1.0 表示初始缩放比例为1.0

默认情况下,在移动端视口的宽度是980px,根据需要,可以修改视口宽度

如果我们需要将一个pc端的网页,在移动端能够完全打开,通常修改设置固定宽度的视口值

<metaname="viewport"content="width=1226">

4.媒体查询

媒体查询:让一个网页在不同的设备上都能够正常显示

视口宽度>=1200px 的屏幕 称为超大屏

视口宽度>=992px 的屏幕 称为大屏

视口宽度>=768px 的屏幕 称为中屏

视口宽度>=576px 的屏幕 称为小屏

视口宽度<576px 的屏幕 称为超小屏

定义媒体查询样式:

screen 表示屏幕

max-width: 1200px 表示最大宽度小于1200px,执行下面的样式

@mediascreenand(max-width:1200px){/* 这里面写的都是样式 */.a{background-color:lightgreen;color:white;}}@mediascreenand(max-width:992px){.a{background-color:lightblue;color:orange;font-size:40px;}}@mediascreenand(max-width:768px){.a{background-color:lightsalmon;color:orchid;font-size:30px;}}@mediascreenand(max-width:576px){.a{background-color:lightseagreen;color:pink;font-size:20px;}}

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

推荐阅读更多精彩内容

  • 第1章 html基本结构 认识HTML: html不是一种编程语言,是一种标志语言 标记语言是由一套标识标签组成的...
    不喝可乐_7889阅读 663评论 0 0
  • 转载请声明 原文链接 关注公众号获取更多资讯 这篇文章主要总结H5的一些新增的功能以及一些基础归纳,这里只是一个提...
    程序员poetry阅读 9,069评论 22 225
  • 1.前端页面有哪三层构成,分别是什么?作用是什么? 结构层 Html 表示层 CSS 行为层 js。 2.你做的页...
    西瓜炒苦瓜阅读 4,628评论 0 7
  • 课程目标: HTML5新标签与特性新增表单属性多媒体标签熟练掌握CSS3选择器熟练掌握CSS3过渡熟练掌握CSS3...
    璐璐熙可阅读 221评论 0 0
  • HTML5 1.HTML5新元素 HTML5提供了新的元素来创建更好的页面结构: 标签描述 定义页面独立的内容区域...
    L怪丫头阅读 2,807评论 0 4