10-H5新特性


目录内容

图片

23 HTML5 新增特性

23.1 语义化标签

图片

以前我们布局基本上都是使用div盒子,但是div盒子对于搜索引擎而言没有任何语义。我们可以将div再细分一下,生成一些语义化的布局标签。于是,HTML5新增加了一些新的标签、新的表单和新的表单属性等。

图片

注意,这些新特性都有兼容性问题,基本是IE9+以上版本的浏览器才支持。

23.2 多媒体标签

使用多媒体标签可以很方便地在页面中嵌入音频和视频,不再使用flash和其他浏览器插件。

23.2.1 视频<video>标签

<video src="文件路径" controls="controls"></video>

里面可以添加的属性(部分):

  • autoplay: autoplay 视频自动播放(谷歌浏览器还需要添加“静音播放”)
  • controls: controls 显示播放控件
  • 宽度: 100% 设置播放器的宽度
  • height: 400 设置播放器的高度
  • loop: loop 设置循环播放
  • src: "xxx" 视频的url地址
  • poster: imgurl 加载等待的画面图片
  • muted: muted 静音播放
<video src="move.mp4" autoplay="autoplay" muted="muted" controls="controls" loop="loop" width="500px">
</video>

尽量使用mp4格式,对各个浏览器兼容性更好,不行再执行ogg格式的视频,还是不行就显示文字,写法如下:

图片

23.2.2 音频<audio>标签

<audio src="文件路径" controls="controls"></audio>

里面可以添加的属性(部分):

  • autoplay:autoplay 自动播放(谷歌禁用了,JS可以解决)
  • controls:controls 显示控件
  • loop:loop 循环播放

图片

23.3 input属性值

之前的input无论是啥都为text,满足不了所有的需求。于是HTML5新增了以下input属性值:

图片

将这些放到input里面,就会有新的效果。

图片

23.4 表单属性

图片

图片图片

可以通过以下设置方式修改placeholder里面的字体颜色:

input::placeholder {
     color: pink;
}

同时注意:search和submit是一对的,这两个都需要在form盒子里面,才能够成为一对。

 <form action="">
        <input type="search" name="搜索" id="搜索" required="required">
        <input type="submit" value="提交">
 </form>

24 CSS3 新增特性

  • 新增的CSS3特性有兼容性问题,ie9+才支持
  • 移动端支持优于PC端

24.1 属性选择器

图片

  1. 通过属性选择 input[id]
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        input[id] {    /* 有id属性的input才会被选中 */
            background-color: pink;
        }
    </style>
</head>

<body>
    <form action="">
        <input type="search" name="搜索" id="搜索">
        <input type="text" name="搜索" >
    </form>
</body>

</html>
  1. 通过属性值选择 input[type="text"]
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        input[type="text"] {    /* type="text"的input才会被选中 */
            background-color: pink;
        }
    </style>
</head>

<body>
    <form action="">
        <input type="search" name="搜索" id="搜索">
        <input type="text" name="搜索" >
    </form>
</body>

</html>
  1. 选择属性值 开头/结尾名称相同 的标签 input[class^=icon]/ input[class$=icon]

如果想要选取下面前3个text表单,可以使用^,选择属性值为icon开头的所有元素:

<form action="">
        <input type="text" class="icon1">
        <input type="text" class="icon2">
        <input type="text" class="icon3">
     <input type="text" class="lihaile">
</form>
input[class^=icon]
        {
           background-color: pink;
        }

使用$,选择属性值为icon结尾的所有元素:

<form action="">
        <input type="text" class="1icon">
        <input type="text" class="2icon">
        <input type="text" class="3icon">
     <input type="text" class="lihaile">
</form>
input[class$=icon]
        {
           background-color: pink;
        }
  1. 选择包含某些元素的属性值 input[class*=icon]
<form action="">
        <input type="text" class="1icon1">
        <input type="text" class="2icon2">
        <input type="text" class="3icon3">
     <input type="text" class="lihaile">
</form>

选取前三个元素,使用 input[class*=icon] ,选择属性值中包含icon的元素:

input[class*=icon]  /*此处权重为 标签选择器1+属性选择器10=11*/
        {
           background-color: pink;
        }

注意:类选择器、属性选择器、伪类选择器,权重都是10

24.2 结构伪类选择器

主要根据文档结构来选择某个元素,常用于选择父级选择器里面的某个子元素

图片

24.2.1 选择第n个元素

当遇到这种情况,我们选择里面的某个元素时,使用class会非常麻烦。

<ul>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
</ul>
  • 选择里面的第一个元素 li:first-child
ul li:first-child {
            background-color: pink;
        }
  • 选择里面的最后一个元素 li:last-child
ul li:last-child {
            background-color: pink;
        }
  • 选择中间的第几个元素 li:nth-child(3)
ul li:nth-child(3){
            background-color: aqua;
        }
  • 选择里面的所有偶数元素 li:nth-child(even)
ul li:nth-child(even){
            background-color: aqua;
        }
  • 选择里面的所有奇数元素 li:nth-child(odd)
ul li:nth-child(odd){
            background-color: aqua;
        }
  • 依据公式进行选择 li:nth-child(n)
ul li:nth-child(n){
            background-color: aqua;
 }

这里的变量必须用n来表示,用n来表示公式,如:2n,(2n)^2等,其中,n从0开始增加,每次增加1。

图片

24.2.2 常用的6个结构伪类选择器

  • :first-child 得到父元素中的第一个子元素
  • :last-child 得到父元素中最后一个子元素
  • :nth-child(n) 得到父元素中第n个子元素
  • :first-of-type 得到指定类型的第一个子元素
  • :last-of-type 得到指定类型的最后一个子元素
  • :nth-of-type(n) 得到指定类型的第n个子元素

注意::nth-child(n)和 :nth-of-type (n) 的区别:

图片

div: nth-child(1)是先从所有子元素中拿到第一个子元素,然后判断是不是div,是则选中,不是则不选。

div: nth-of-type(1)是先拿出父元素中所有的div盒子,然后再选择第一个子div。

24.3 伪元素选择器

当我们想要实现这个小三角:

图片

或者实现鼠标放在图片上,图片就会有一个小的遮罩的效果:

图片

往常我们是需要给小三角和遮罩一个div,放到html结构中,很麻烦。

现在,可以利用CSS创建新标签元素,而不需要HTML标签,从而简化HTML结构,语法: element::before {}

图片

  • before和after会创建一个元素,但是属于行内元素
  • 新创建的这个元素在文档树中是找不到的,所以我们称为伪元素
  • before和after必须有content属性
  • before在父元素内容的前面创建元素,after在父元素内容的后面插入元素
  • 伪元素选择器和标签选择器一样,权重为1
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div::before{    /* 权重为1+1=2 */
            content: "你";
        }
        div::after{
            content: "猪";
        }
    </style>
</head>

<body>
   <div>是</div>
</body>

</html>

伪元素就是在父级元素里面的前面/后面插入一个行内元素,如上,我们在父级元素的前面插入一个,在父级元素的后面插入一个

其中伪元素里面必须包含content属性。

24.5 盒子模型

原来的盒子模型:边框和padding都会撑大盒子。

现在:

  • box-sizing: content-box; (默认)

    盒子大小为width+padding+border,padding和border撑开盒子

  • box-sizing: border-box;

    盒子大小为width和height,padding和border不会撑开盒子

如下div,最终大小为300*300:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            width: 300px;
            height: 300px;
            background-color: aqua;
            border: 20px solid black;
            padding: 5px;
            box-sizing: border-box;
        }
    </style>
</head>

<body>
   <div></div>
</body>

</html>

24.6 模糊滤镜 filter:blur(5px);

filter属性:将元素加上模糊/颜色偏移等效果

filter:函数();

filter:blur(5px);    blur模糊处理,数值越大越模糊

图片

24.7 calc 函数

calc() 可以在声明CSS属性值时执行一些计算:

width: calc(100% - 80px);

效果:子盒子永远比父盒子小80像素

注意:括号里面可以使用+- */来计算

24.8 过渡效果

不使用Flash动画和JavaScript就可以实现动画效果(一个样式变化为另一个样式)

transition:变化的属性 花费时间 运动曲线 何时开始
  • 变化的属性:如果宽度变化,那么这里就为width
  • 花费时间:完成变化所需要的时间0.5s
  • 运动曲线:默认为ease
  • 何时开始:默认为0s
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            width: 300px;
            height: 300px;
            transition: width 1s ease 0s;
            background-color: blueviolet
        }
        div:hover{
            width: 600px;
        }
    </style>
</head>

<body>
   <div></div>
</body>

</html>

我们定义了一个300X300px的紫色盒子,这个盒子加了一个过渡动画:当鼠标放到盒子上时,就将宽度变为600px,执行时间为1s。

注意:过渡一般搭配hover进行使用

如果想要多个属性同时过渡变化,有两种方式:

  • ①加逗号
transition: width 1s, height 1s;
  • ②直接all
transition: all 1s ease 0s;