HTML5 Video(视频)学习笔记
一、HTML5 视频简介
HTML5 引入了 <video> 元素,用于在网页上嵌入视频内容。这种方式取代了传统的 Flash 插件,使得视频的展示更加标准化和便捷。HTML5 的 <video> 元素为开发者提供了一种简单且兼容性强的方法来嵌入视频,同时也支持多种视频格式。
二、浏览器支持情况
-
Internet Explorer 9+、Firefox、Opera、Chrome 和 Safari 都支持
<video>元素。 -
注意:Internet Explorer 8 或更早版本不支持
<video>元素。
三、基本用法
1. 基本语法
在 HTML5 中嵌入视频的基本语法如下:
HTML复制
<video width="320" height="240" controls><source src="movie.mp4" type="video/mp4"><source src="movie.ogg" type="video/ogg">您的浏览器不支持 Video 标签。
</video>
预览
-
<video>元素提供了播放、暂停和音量控件来控制视频。 -
width和height属性用于控制视频的尺寸。如果设置了这些属性,浏览器会在页面加载时保留所需的视频空间,避免页面因视频加载而改变布局。 -
<video>标签之间插入的内容是为不支持<video>元素的浏览器提供的备用内容。
2. 支持的视频格式
目前,<video> 元素支持三种视频格式:
-
MP4:带有 H.264 视频编码和 AAC 音频编码的 MPEG 4 文件。
-
WebM:带有 VP8 视频编码和 Vorbis 音频编码的 WebM 文件。
-
Ogg:带有 Theora 视频编码和 Vorbis 音频编码的 Ogg 文件。
不同浏览器对这些格式的支持情况如下表所示:
| 浏览器 | MP4 | WebM | Ogg |
|---|---|---|---|
| Internet Explorer | YES | NO | NO |
| Chrome | YES | YES | YES |
| Firefox | YES | YES | YES |
| Safari | YES | NO | NO |
| Opera | YES (从 Opera 25 起) | YES | YES |
3. 视频格式的 MIME 类型
| 格式 | MIME 类型 |
|---|---|
| MP4 | video/mp4 |
| WebM | video/webm |
| Ogg | video/ogg |
四、使用 DOM 控制视频
<video> 元素支持多种方法、属性和事件,可以通过 JavaScript 进行控制。例如:
-
方法:
play()、pause()等,用于控制视频的播放和暂停。 -
属性:
paused、width等,可以读取或设置视频的状态和尺寸。 -
事件:
play、pause等,可以监听视频的播放和暂停事件。
示例代码
以下是一个简单的示例,展示如何使用 JavaScript 控制 <video> 元素:
HTML复制
<video id="myVideo" width="320" height="240" controls><source src="movie.mp4" type="video/mp4">您的浏览器不支持 Video 标签。
</video>
<button onclick="playVideo()">播放</button>
<button onclick="pauseVideo()">暂停</button><script>function playVideo() {document.getElementById("myVideo").play();}function pauseVideo() {document.getElementById("myVideo").pause();}
</script>
预览
五、相关标签
1. <source> 标签
<source> 标签用于定义多种媒体资源,例如 <video> 和 <audio>。它可以链接不同的视频文件,浏览器将使用第一个可识别的格式。
2. <track> 标签
<track> 标签用于定义在媒体播放器中的文本轨迹,例如字幕、章节等。
六、总结
HTML5 的 <video> 元素为网页视频展示提供了一种简单、标准化的方法。通过合理使用 <video> 元素及其相关属性和方法,可以轻松地在网页上嵌入视频,并实现丰富的交互功能。同时,了解不同浏览器对视频格式的支持情况,可以帮助我们更好地选择合适的视频格式,确保视频在不同浏览器中都能正常播放。
相关文章:
HTML5 Video(视频)学习笔记
一、HTML5 视频简介 HTML5 引入了 <video> 元素,用于在网页上嵌入视频内容。这种方式取代了传统的 Flash 插件,使得视频的展示更加标准化和便捷。HTML5 的 <video> 元素为开发者提供了一种简单且兼容性强的方法来嵌入视频,同时也…...
怎么让一台云IPPBX实现多家酒店相同分机号码一起使用
下面用到的IPPBX是我们二次开发后的成品,支持各种云服务器一键安装,已经写好了一键安装包,自动识别系统环境,安装教程这里就不再陈述了! 前言需求 今天又遇到了一个客户咨询,关于部署一台云IPPBX…...
Java模板方法模式详解
模板方法模式详解 一、模式定义 模板方法模式(Template Method Pattern)定义一个操作中的算法骨架,将某些步骤延迟到子类实现。 二、核心结构 1. 抽象模板类 public abstract class AbstractTemplate {// 模板方法(final防止子类覆盖)pu…...
Vite 内联 CSS 和 JS 的解决方案
使用 vite-plugin-singlefile(推荐) 这个插件专门用于将整个 Vite 应用打包成单个 HTML 文件,内联所有 JS 和 CSS。 安装 pnpm i vite-plugin-singlefile -D配置 vite.config.js import { defineConfig } from vite import { viteSingleF…...
蓝桥杯2024JavaB组的一道真题的解析
文章目录 1.问题描述2.问题描述3.思路分析4.代码分析 1.问题描述 这个是我很久之前写的一个题目,当时研究了这个题目好久,发布了一篇题解,后来很多人点赞,我都没有意识到这个问题的严重性,我甚至都在怀疑自己…...
计算机视觉算法实战——基于YOLOv8的行人流量统计系统
✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连✨ 引言:智能客流分析的市场需求 在零售、交通、安防等领域,准确的行人流量统计对于商业决策、公共安全管理…...
在PyTorch中使用GPU加速:从基础操作到模型部署
本文将通过具体代码示例,详细介绍如何在PyTorch中利用GPU进行张量计算和模型训练,包含设备查询、数据迁移以及模型部署等完整流程。 1. 查看GPU硬件信息 使用 nvidia-smi 命令检查GPU状态和进程信息: # 查看GPU信息 !nvidia-smi 输出示例&…...
机器学习ML极简指南
机器学习是现代AI的核心,从推荐系统到自动驾驶,无处不在。但每个智能应用背后,都离不开那些奠基性的模型。本文用最简练的方式拆解核心机器学习模型,助你面试时对答如流,稳如老G。 线性回归 线性回归试图通过"最…...
flux绘画模型介绍
一、Flux绘画模型的核心定义与背景 Flux绘画模型是由Black Forest Labs开发的先进AI图像生成模型,其核心团队源自Stable Diffusion的创始成员(如Robin Rombach),结合了Stability AI的技术积累与创新突破。该模型于2024年8月首次发…...
LLM驱动的智能体:基于GPT的对话智能体开发指南
前言 大语言模型(LLM, Large Language Model)正在彻底改变智能体(Agent)的设计和实现方式。从简单的聊天机器人到复杂的自动化助手,基于GPT等LLM的对话智能体已经在客服、教育、办公自动化、编程助手等领域得到了广泛…...
项目之Boost搜索引擎
目录 搜索引擎项目背景 搜索引擎的宏观原理 搜索引擎技术栈和项目环境 搜索引擎具体原理(正排索引和倒排索引) 正排索引 倒排索引 编写数据去标签与数据清洗的模块 Parser 从boost官网导入HTML网页数据 去标签 构建 Parser 模块 递归式获取 HTML 文件的带文件名称…...
MyBatis 动态SQL 详解!
目录 一、 什么是动态 SQL?二、 为什么需要动态 SQL?三、 MyBatis 动态 SQL 标签四、 标签详解及示例1、 if 标签2、 choose、when、otherwise 标签3、 where 标签4、 set 标签5、 foreach 标签6、 sql、include 标签 五、 总结 🌟我的其他文…...
本节课课堂总结
匿名子类: 说明 和 Java 一样,可以通过包含带有定义或重写的代码块的方式创建一个匿名的子类。 单例对象(伴生对象) Scala语言是完全面向对象的语言,所以并没有静态的操作(即在Scala中没有静态的概念&a…...
【Linux学习笔记】开发工具git和gbd和cgbd的介绍和使用
【Linux学习笔记】开发工具git和gbd和cgbd的介绍和使用 🔥个人主页:大白的编程日记 🔥专栏:Linux学习笔记 文章目录 【Linux学习笔记】开发工具git和gbd和cgbd的介绍和使用前言一. 版本控制器Git1.1版本控制器1.2 git 简史1.3 安…...
php的高速缓存
部署方法 在我们安装的nginx中默认不支持memc和srcache功能,需要借助第三方模块来让nginx支持此功能。 tar zxf srcache-nginx-module-0.33.tar.gz tar zxf memc-nginx-module-0.20.tar.gz 下载这俩个模块,然后编译安装的时候加进去 编译安装完成之后…...
Real-Time Anomaly Detection of Network Traffic Basedon CNN
1知识点补充 边缘计算模型 成为一种新的分布式数据处理方式,通过靠近数据侧,及时响应用户的计算请求,降低数据传输的网络延迟。 边缘节点是边缘计算架构中最基础的物理或逻辑单元,指位于网络边缘(靠近数据源或用户&a…...
RHCSA LINUX系统文件管理
一.7种文件类型 注意:Linux系统文件名的后缀只是为了方便用户识别文件类型 Linux系统设计哲学:一切皆文件 1.使用 “ls -l” 命令查看到的第一个字符,对应不同文件类型及说明如下: ①“-”:普通文件,类…...
AQUA爱克泳池设备入驻济南校园,以品质筑牢游泳教育安全防线
在推进校园体育教育高质量发展的时代背景下,游泳作为一项兼具运动价值与生存技能的重要课程,正被越来越多的学校纳入教学体系。泳池作为开展游泳教学与运动的关键设施,其配套泳池设备的先进性与安全性愈发受到重视。作为泳池水处理设备行业的…...
基于CNN实现电力负荷多变量时序预测(PyTorch版)
前言 系列专栏:【深度学习:算法项目实战】✨︎ 涉及医疗健康、财经金融、商业零售、食品饮料、运动健身、交通运输、环境科学、社交媒体以及文本和图像处理等诸多领域,讨论了各种复杂的深度神经网络思想,如卷积神经网络、循环神经网络、生成对抗网络、门控循环单元、长短期记…...
网络空间安全(50)JavaScript基础语法
一、变量声明 ①var: 早期的变量声明方式,函数作用域。 ②let: 块级作用域,推荐在现代 JavaScript 中使用。 ③const: 块级作用域,用于声明常量,值不可变。 var name "Alice"; let age 30; const PI 3.14159; 二、数…...
深入理解二叉树、B树与B+树:原理、应用与实现
文章目录 引言一、二叉树:基础而强大的结构基本概念特性分析Java实现应用场景 二、B树:适合外存的多路平衡树基本概念关键特性查询流程示例Java简化实现典型应用 三、B树:数据库索引的首选核心改进优势分析范围查询示例Java简化实现实际应用 …...
【网络流 图论建模 最大权闭合子图】 [六省联考 2017] 寿司餐厅
题目描述: P3749 [六省联考 2017] 寿司餐厅 题目描述 Kiana 最近喜欢到一家非常美味的寿司餐厅用餐。 每天晚上,这家餐厅都会按顺序提供 n n n 种寿司,第 i i i 种寿司有一个代号 a i a_i ai 和美味度 d i , i d_{i, i} di,i&…...
mysql对表,数据,索引的操作sql
对表的操作 新建表 创建一个名为rwh_test的表,id为主键自增 -- 新建表 CREATE TABLE rwh_test(id int NOT NULL auto_increment PRIMARY KEY COMMENT 主键id,username VARCHAR(20) DEFAULT NULL COMMENT 用户名,age int DEFAULT NULL COMMENT 年龄,create_date d…...
verl单机多卡与多机多卡使用经验总结
文章目录 I. 前言II. SFT2.1 单机多卡2.2 多机多卡 III. RL (GRPO)3.1 单机多卡3.2 多机多卡2.3 模型转换 I. 前言 在上一篇文章verl:一个集SFT与RL于一体的灵活大模型post-training框架 (快速入门) 中,初步探讨了verl框架的基础使用方法。在实际工业级…...
胶铁一体化产品介绍
•一体化结构特点介绍 胶框/铁框一体化技术最早在韩国采用,07年以来由于要求背光越做越薄。在采用0.4mm及以下厚度的LGP时,胶框及背光就会变得异常软,胶框不易组装,铁框松动等问题。 由于胶框和铁框是紧紧粘合在一起的,这正可以解…...
蓝桥杯刷题记录【并查集001】(2024)
主要内容:并查集 并查集 并查集的题目感觉大部分都是模板题,上板子!! class UnionFind:def __init__(self, n):self.pa list(range(n))self.size [1]*n self.cnt ndef find(self, x):if self.pa[x] ! x:self.pa[x] self.fi…...
基于BusyBox构建ISO镜像
1. 准备 CentOS 7.9 3.10.0-957.el7.x86_64VMware Workstation 建议:系统内核<3.10.0 使用busybox < 1.33.2版本 2. 安装busybox # 安装依赖 yum install syslinux xorriso kernel-devel kernel-headers glibc-static ncurses-devel -y# 下载 wget https://…...
Multisim14.3的安装步骤
Multisim14.3的安装步骤 安装包链接 右击Install.exe,以管理员身份运行 激活前关闭杀毒软件 右击,以管理员身份运行 依次右键【Base Edition】、【Full Edition】、【Power ProEdition】、【Full Edition】、【Power ProEdition】,选择【…...
搭建环境-opencv-qt
CMake Error at cmake/OpenCVCompilerOptimizations.cmake:647 (message): Compiler doesnt support baseline optimization flags: Call Stack (most recent call first): cmake/OpenCVCompilerOptions.cmake:344 (ocv_compiler_optimization_options) CMakeList 解决方…...
【愚公系列】《高效使用DeepSeek》050-外汇交易辅助
🌟【技术大咖愚公搬代码:全栈专家的成长之路,你关注的宝藏博主在这里!】🌟 📣开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主! 👉 江湖人称"愚公搬代码",用七年如一日的精神深耕技术领域,以"…...
