html 停止渲染_HTML基础篇--17HTML之视频播放

视频是网页承载内容很重要的一个元素,也是必不可少的网页表现形式(图、文、表、视、音)之一。曾经网页要想播放视频、制作游戏,必须得用第三方插件flash。不仅编写代码要使用额外的语言,浏览器也必须得装第三方插件,非常不方便。随着html5标准逐渐普及,移动端、pc端开始抛弃flash,如今几乎所有的浏览器都使用html5来制作视频。

目标

  1. 了解Flash为何会被淘汰?
  2. 如何设置视频播放?
  3. 视频播放支持哪几种视频格式?

flash崛起--网页标准的耻辱

flash是Adobe公司其中之一的产品。它发起于W3C与WHATWG的第五代web标准之争,它捡了个大便宜,乘机定义网页媒体标准。

81a4b140ed4915f590df4f8f05814f63.png

W3C与WHATWG的第五代web标准之争

flash填补了当时网页只有文字和图片的单调世界,将媒体(视频、音频、游戏)引入了网页,将网页带进多彩的世界。

Flash能够用仅仅十几K到几百K的体积,呈现出放大也不会失真的矢量彩色动图,甚至还能够做出足以令人沉迷一整天的Flash小游戏。

8ddeebaeaf81f9bd89d9321b5838360a.gif

火柴人

Flash用第三方插件的身份,几乎制霸了网页媒体的标准,让W3C尴尬不已,甚至从某种程度上说,让真正的网页标准推广受阻。

flash衰败--HTML5崛起并全面普及

2010年4月,苹果CEO公开表示从此苹果所有产品不再支持flash。flash从此慢慢丧失移动端的市场和地位。

75b5e9856b0a2b2da024d147e0da6655.png

乔布斯支持html5

2012年,安卓宣布不再支持Flash,从此flash彻底失去了移动端市场和地位。

2012年html5标准确立,html5在逐渐制霸移动端的地位时,也直接冲击了flash仅剩的桌面市场,flash桌面市场的份额在逐步下降。

各大浏览器逐步默认禁用Flash,现2019年几乎都全部禁用。

3f061d71571f520aa8b5f232c3b14961.png

默认禁用Flash

Adobe将在2020年停止开发和更新flash。

46811f0291b1d525e3b3bf9d2ce32a74.png

2020年停止开发和更新flash

flash兴起衰败皆因自己

Flash以第三方插件的身份,做着平台该做的事情,但没有推动行业标准统一化,反而企图私立标准。

随着功能的增多,能解码编码H.264,能进行3D渲染,能播放7.1声道环绕声等,功能集于一身变得臃肿,效率变得低下。

89c2bca28201ed28c019de97bba8c57f.png

Flash非常不安全。Flash能够运行相当复杂的代码,这让Flash非常容易被渗透。加上Adobe在安全方面的不上心,这令Flash安全问题频发。

Flash很不稳定。作为一个插件,它自身频频崩溃也就罢了,还经常拉着浏览器乃至操作系统一起殉情。

Flash加剧了手机的耗电量。

html5媒体新标准--Video标签

作用是在 HTML 页面中嵌入视频元素。Video定义视频,比如电影片段或其他视频流。

1af4a3490001c1988218e00517873e0c.png

视频播放

Video标签的属性

  • src 视频的播放源
  • controls 浏览器自带的控制条
  • width 视频宽度
  • height 视频高度
  • poster 视频封面
  • autoplay 自动播放
  • preload 预加载

有四个是必须的属性:src、controls、width、height属性。

cd4054de1df9e870af34837080a4735e.png

视频播放代码

source标签

元素可以链接不同格式的视频文件。浏览器将使用第一个可识别的格式。

  • src 视频的播放源
  • Type 视频格式 MP4, WebM, 和 Ogg
ba53f23e88a7ee1917d721270e818adf.png

支持多格式的视频

总结

4686c6ca8c3259f4c3cede888b67c56d.png

video标签体系

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js 是一个流行的前端框架,提供了一种简单而强大的方式来处理动态渲染页面。v-for 是 Vue.js 中最常用的指令之一,用于循环渲染列表数据。下面我们就来详解一下 Vue.js 中的 v-for 指令。 ## v-for 指令 v-for 指令可以循环渲染一个数组或对象的属性,它的语法格式如下: ```html <div v-for="(item, index) in items" :key="index">{{ item }}</div> ``` 上面的代码中,items 是一个数组,v-for 指令会将数组中的每个元素渲染成一个 div 元素。在循环过程中,item 和 index 分别表示数组的元素和索引。 其中,:key 是必须的属性,用于给每个渲染出的元素指定一个唯一的标识符,以便 Vue.js 能够跟踪每个元素的状态变化。 在 v-for 指令中,还可以使用对象的属性进行循环渲染: ```html <div v-for="(value, key) in object" :key="key">{{ key }}: {{ value }}</div> ``` 上面的代码中,object 是一个对象,v-for 指令会将对象的每个属性渲染成一个 div 元素。在循环过程中,value 和 key 分别表示对象的属性值和属性名。 ## v-for 嵌套 在 Vue.js 中,v-for 指令可以嵌套使用,实现更复杂的渲染效果。例如,可以循环渲染一个二维数组: ```html <div v-for="row in matrix" :key="row[0]"> <div v-for="cell in row" :key="cell">{{ cell }}</div> </div> ``` 上面的代码中,matrix 是一个二维数组,v-for 指令会将每一行渲染成一个 div 元素,然后在每行中再循环渲染每个元素,即每个单元格渲染成一个 div 元素。 ## v-for 和 v-if 结合使用 在 Vue.js 中,v-for 指令和 v-if 指令可以结合使用,实现更灵活的渲染效果。例如,可以根据条件过滤渲染的元素: ```html <div v-for="item in items" v-if="item.visible" :key="item.id">{{ item.name }}</div> ``` 上面的代码中,items 是一个数组,v-for 指令会将数组中的每个元素渲染成一个 div 元素。在渲染过程中,只有 visible 属性为 true 的元素才会被渲染。 ## 总结 v-for 指令是 Vue.js 中常用的指令之一,用于循环渲染列表数据。在使用 v-for 指令时,需要注意给每个渲染出的元素指定一个唯一的标识符,以便 Vue.js 能够跟踪每个元素的状态变化。另外,v-for 指令还可以嵌套使用,实现更复杂的渲染效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值