css3新特性_HTML5和css3(一)

一、什么是 HTML5
  1. HTML5 的概念与定义

  • 是一个新版本的 HTML 语言,定义了新的标签、特性和属性

  • 拥有一个强大的技术集,这些技术集是指:HTML5CSS3javascript, 这也是广义上的 HTML5

  • 定义:HTML5 定义了 HTML 标准的最新版本,是对 HTML 的第五次重大修改,号称下一代的 HTML

  • 两个概念:

HTML5 拓展了哪些内容

  • 语义化标签

  • 本地存储

  • 兼容特性

  • 2D3D

  • 动画、过渡

  • CSS3 特性

  • 性能与集成

HTML5 的现状

 绝对多数新的属性,都已经被浏览器所支持,最新版本的浏览器已经开始陆续支持最新的特性,

 总的来说:HTML5 已经是大势所趋

二、HTML5 新增标签
  1. 什么是语义化

  2. 新增了那些语义化标签

  • header   ---  头部标签

  • nav        ---  导航标签

  • article ---   内容标签

  • section ---   块级标签

  • aside     ---   侧边栏标签

  • footer   ---   尾部标签

使用语义化标签的注意

  • 语义化标签主要针对搜索引擎

  • 新标签可以使用一次或者多次

  • IE9 浏览器中,需要把语义化标签都转换为块级元素

  • 语义化标签,在移动端支持比较友好,

  • 另外,HTML5 新增的了很多的语义化标签,随着课程深入,还会学习到其他的

三、多媒体音频标签
  1. 多媒体标签有两个,分别是

  • 音频  -- audio

  • 视频  -- video

audio 标签说明

  • 可以在不使用标签的情况下,也能够原生的支持音频格式文件的播放,

  • 但是:播放格式是有限的

audio 支持的音频格式

  • audio 目前支持三种格式

audio 的参数

5、audio 代码演示

<body>  <!-- 注意:在 chrome 浏览器中已经禁用了 autoplay 属性 -->  <!-- <audio src="./media/snow.mp3" controls autoplay>audio> -->  <!--     因为不同浏览器支持不同的格式,所以我们采取的方案是这个音频准备多个文件   -->  <audio controls>    <source src="./media/snow.mp3" type="audio/mpeg" />  audio>body>
四、多媒体视频标签
  1. video 视频标签

  • 目前支持三种格式

语法格式

<video src="./media/video.mp4" controls="controls">video>

video 参数

video 代码演示

<body>      <video controls="controls" autoplay muted loop poster="./media/pig.jpg">    <source src="./media/video.mp4" type="video/mp4">    <source src="./media/video.ogg" type="video/ogg">  video>body>

多媒体标签总结

  • 音频标签与视频标签使用基本一致

  • 多媒体标签在不同浏览器下情况不同,存在兼容性问题

  • 谷歌浏览器把音频和视频标签的自动播放都禁止了

  • 谷歌浏览器中视频添加 muted 标签可以自己播放

  • 注意:重点记住使用方法以及自动播放即可,其他属性可以在使用时查找对应的手册

五、新增 input 标签

3f97a3fe2ea0c1a321da544e68bfb6f2.png

六、新增表单属性

3620877c4ef46c789a9f6d6509754af4.png

七、CSS3 属性选择器(上)
  1. 什么是 CSS3

  • CSS2 的基础上拓展、新增的样式

CSS3 发展现状

  • 移动端支持优于 PC

  • CSS3 目前还草案,在不断改进中

  • CSS3 相对 H5,应用非常广泛

属性选择器列表

e08b56f8e61261cbcb613be2ecdc21c8.png

属性选择器代码演示

button {  cursor: pointer;}button[disabled] {  cursor: default}
八、CSS3 属性选择器(下)
  1. 代码演示

    input[type=search] {  color: skyblue;}span[class^=black] {  color: lightgreen;}span[class$=black] {  color: lightsalmon;}span[class*=black] {  color: lightseagreen;}
九、结构伪类选择器
  1. 属性列表

    f875276b4c336d7e35e2d86fc14d1ffd.png

  2. 代码演示

    ul li:first-child {  background-color: lightseagreen;}ul li:last-child {  background-color: lightcoral;}ul li:nth-child(3) {  background-color: aqua;}
十、nth-child 参数详解
  1. nth-child 详解

  • 注意:本质上就是选中第几个子元素

  • n 可以是数字、关键字、公式

  • n 如果是数字,就是选中第几个

  • 常见的关键字有 even 偶数、odd 奇数

  • 常见的公式如下(如果 n 是公式,则从 0 开始计算)

  • 但是第 0 个元素或者超出了元素的个数会被忽略

  • 29a12b0490a33c8d576afd43e0afb94f.png

代码演示

<style>  /* 偶数 */  ul li:nth-child(even) {    background-color: aquamarine;  }  /* 奇数 */  ul li:nth-child(odd) {    background-color: blueviolet;  }  /*n 是公式,从 0 开始计算 */  ul li:nth-child(n) {    background-color: lightcoral;  }  /* 偶数 */  ul li:nth-child(2n) {    background-color: lightskyblue;  }  /* 奇数 */  ul li:nth-child(2n + 1) {    background-color: lightsalmon;  }  /* 选择第 0 5 10 15, 应该怎么选 */  ul li:nth-child(5n) {    background-color: orangered;  }  /* n + 5 就是从第5个开始往后选择 */  ul li:nth-child(n + 5) {    background-color: peru;  }  /* -n + 5 前五个 */  ul li:nth-child(-n + 5) {    background-color: tan;  }style>
十一、nth-child 和  nt-of-type 的区别
  1. 代码演示

    <style>  div :nth-child(1) {    background-color: lightblue;  }  div :nth-child(2) {    background-color: lightpink;  }  div span:nth-of-type(2) {    background-color: lightseagreen;  }  div span:nth-of-type(3) {    background-color: #fff;  }style>
  1. 区别

  • nth-child  选择父元素里面的第几个子元素,不管是第几个类型

  • nt-of-type  选择指定类型的元素

十二、伪元素选择器
  1. 伪类选择器502842355c3c138b64d79288c2eab0da.png

  2. 伪类选择器注意事项

  • beforeafter 必须有 content 属性

  • before 在内容前面,after 在内容后面

  • beforeafter 创建的是一个元素,但是属于行内元素

  • 创建出来的元素在 Dom 中查找不到,所以称为伪元素

  • 伪元素和标签选择器一样,权重为 1

代码演示

<style>    div {      width: 100px;      height: 100px;      border: 1px solid lightcoral;    }    div::after,    div::before {      width: 20px;      height: 50px;      text-align: center;      display: inline-block;    }    div::after {      content: '德';      background-color: lightskyblue;    }    div::before {      content: '道';      background-color: mediumaquamarine;    }  style>
十三、伪元素的案例
  1. 添加字体图标

    p {   width: 220px;   height: 22px;   border: 1px solid lightseagreen;   margin: 60px;   position: relative;}p::after {  content: '\ea50';  font-family: 'icomoon';  position: absolute;  top: -1px;  right: 10px;}
十四、2D 转换之 translate
  1. 2D 转换

  • 2D 转换是改变标签在二维平面上的位置和形状

  • 移动:translate

  • 旋转:rotate

  • 缩放:scale

translate 语法

transform: translate(x, y)transform: translateX(n)transfrom: translateY(n)
  • x 就是 x 轴上水平移动

  • y 就是 y 轴上水平移动

重点知识点

  • 2D 的移动主要是指 水平、垂直方向上的移动

  • translate 最大的优点就是不影响其他元素的位置

  • translate 中的100%单位,是相对于本身的宽度和高度来进行计算的

  • 行内标签没有效果

代码演示

div {  background-color: lightseagreen;  width: 200px;  height: 100px;  /* 平移 */  /* 水平垂直移动 100px */  /* transform: translate(100px, 100px); */  /* 水平移动 100px */  /* transform: translate(100px, 0) */  /* 垂直移动 100px */  /* transform: translate(0, 100px) */  /* 水平移动 100px */  /* transform: translateX(100px); */  /* 垂直移动 100px */  transform: translateY(100px)}
十五、让一个盒子水平垂直居中
  • 看代码

十六、2D 转换 rotate
  1. rotate 旋转

  • 2D 旋转指的是让元素在二维平面内顺时针或者逆时针旋转

rotate 语法

/* 单位是:deg */transform: rotate(度数)

重点知识点

  • rotate 里面跟度数,单位是 deg

  • 角度为正时,顺时针,角度为负时,逆时针

  • 默认旋转的中心点是元素的中心点

代码演示

img:hover {  transform: rotate(360deg)}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值