JS监听全屏变化的5个事件详解
从现在开始,努力学习吧!本文《JS监听全屏状态变化的5个API事件详解》主要讲解了等等相关知识点,我会在golang学习网中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容吧,希望能帮到你!
JS监听全屏状态变化主要通过fullscreenchange事件及浏览器前缀版本实现。1. 使用document.addEventListener('fullscreenchange', ...)监听标准事件;2. 添加mozfullscreenchange、webkitfullscreenchange、msfullscreenchange事件兼容Firefox、Chrome/Safari/Opera、IE/Edge浏览器;3. 通过封装requestFullscreen和exitFullscreen函数处理不同浏览器的API差异;4. 利用isFullscreen函数检测当前是否处于全屏模式,分别检查各浏览器对应的属性;5. 全屏样式调整可通过CSS媒体查询、JavaScript动态修改类名或CSS变量实现;6. 安全性方面需依赖用户交互触发全屏、提供退出方式、避免欺骗内容、使用HTTPS;7. 检测浏览器是否支持全屏API可通过判断document和element是否存在相关属性和方法。

JS监听全屏状态变化,主要是通过监听浏览器提供的全屏API事件来实现。这允许你捕获用户进入或退出全屏模式的动作,并据此调整你的网页布局或执行其他相关操作。

// 监听全屏状态变化事件
document.addEventListener('fullscreenchange', function (event) {
if (document.fullscreenElement) {
// 进入全屏
console.log('进入全屏模式');
} else {
// 退出全屏
console.log('退出全屏模式');
}
});
// 兼容不同浏览器的全屏事件
document.addEventListener('mozfullscreenchange', function (event) {
// Firefox
if (document.mozFullScreenElement) {
console.log('进入 Firefox 全屏');
} else {
console.log('退出 Firefox 全屏');
}
});
document.addEventListener('webkitfullscreenchange', function (event) {
// Chrome, Safari, Opera
if (document.webkitFullscreenElement) {
console.log('进入 Webkit 全屏');
} else {
console.log('退出 Webkit 全屏');
}
});
document.addEventListener('msfullscreenchange', function (event) {
// IE, Edge
if (document.msFullscreenElement) {
console.log('进入 IE/Edge 全屏');
} else {
console.log('退出 IE/Edge 全屏');
}
});
// 请求全屏的函数
function requestFullscreen(element) {
if (element.requestFullscreen) {
element.requestFullscreen();
} else if (element.mozRequestFullScreen) {
element.mozRequestFullScreen(); // Firefox
} else if (element.webkitRequestFullscreen) {
element.webkitRequestFullscreen(); // Chrome, Safari and Opera
} else if (element.msRequestFullscreen) {
element.msRequestFullscreen(); // IE/Edge
}
}
// 退出全屏的函数
function exitFullscreen() {
if (document.exitFullscreen) {
document.exitFullscreen();
} else if (document.mozCancelFullScreen) {
document.mozCancelFullScreen(); // Firefox
} else if (document.webkitExitFullscreen) {
document.webkitExitFullscreen(); // Chrome, Safari and Opera
} else if (document.msExitFullscreen) {
document.msExitFullscreen(); // IE/Edge
}
}
// 示例:点击按钮切换全屏
const button = document.getElementById('fullscreenButton');
button.addEventListener('click', function() {
if (!document.fullscreenElement && !document.mozFullScreenElement && !document.webkitFullscreenElement && !document.msFullscreenElement) {
requestFullscreen(document.documentElement); // 进入全屏
} else {
exitFullscreen(); // 退出全屏
}
});全屏API事件处理全屏切换,核心在于fullscreenchange事件以及各个浏览器前缀的版本(mozfullscreenchange、webkitfullscreenchange、msfullscreenchange)。

全屏API在不同浏览器中的兼容性问题怎么解决?
要解决全屏API在不同浏览器中的兼容性问题,核心在于编写兼容性代码,检测并使用正确的API方法。因为不同浏览器对全屏API的实现方式略有不同,主要体现在方法名称和属性名称上。

- 检测浏览器前缀: 针对不同的浏览器,可能需要使用不同的前缀,如
moz(Firefox)、webkit(Chrome、Safari)、ms(IE/Edge)。 - 封装全屏函数: 创建一个函数来处理进入和退出全屏的逻辑,函数内部检测浏览器类型并调用相应的API。
- 使用统一的事件监听: 监听各种带有浏览器前缀的
fullscreenchange事件,确保在任何浏览器中都能捕获全屏状态的变化。
以下是一个更完善的示例,展示了如何处理全屏请求和退出,并考虑到不同浏览器的兼容性:
function isFullscreen() {
return document.fullscreenElement ||
document.mozFullScreenElement ||
document.webkitFullscreenElement ||
document.msFullscreenElement;
}
function requestFullscreen(element) {
if (element.requestFullscreen) {
element.requestFullscreen();
} else if (element.mozRequestFullScreen) {
element.mozRequestFullScreen();
} else if (element.webkitRequestFullscreen) {
element.webkitRequestFullscreen();
} else if (element.msRequestFullscreen) {
element.msRequestFullscreen();
}
}
function exitFullscreen() {
if (document.exitFullscreen) {
document.exitFullscreen();
} else if (document.mozCancelFullScreen) {
document.mozCancelFullScreen();
} else if (document.webkitExitFullscreen) {
document.webkitExitFullscreen();
} else if (document.msExitFullscreen) {
document.msExitFullscreen();
}
}
function toggleFullscreen(element) {
if (isFullscreen()) {
exitFullscreen();
} else {
requestFullscreen(element || document.documentElement); // 默认全屏整个文档
}
}
// 监听全屏状态变化
document.addEventListener('fullscreenchange', function (event) {
console.log('Fullscreen changed (generic)');
});
document.addEventListener('mozfullscreenchange', function (event) {
console.log('Fullscreen changed (Mozilla)');
});
document.addEventListener('webkitfullscreenchange', function (event) {
console.log('Fullscreen changed (Webkit)');
});
document.addEventListener('msfullscreenchange', function (event) {
console.log('Fullscreen changed (MS)');
});
// 使用示例
const fullscreenButton = document.getElementById('fullscreenButton');
fullscreenButton.addEventListener('click', function() {
toggleFullscreen(document.documentElement);
});如何检测当前是否处于全屏模式?
检测当前是否处于全屏模式,需要检查浏览器提供的不同属性,这些属性指示了当前文档或元素是否正在全屏显示。与请求全屏类似,不同的浏览器使用不同的属性。
以下代码展示了如何跨浏览器检测全屏状态:
function isFullscreen() {
return document.fullscreenElement ||
document.mozFullScreenElement ||
document.webkitFullscreenElement ||
document.msFullscreenElement ||
false; // 如果以上属性都不存在,则返回 false
}
// 使用示例
if (isFullscreen()) {
console.log('当前处于全屏模式');
} else {
console.log('当前不是全屏模式');
}这段代码定义了一个isFullscreen函数,它会检查以下属性:
document.fullscreenElement: W3C标准属性,现代浏览器支持。document.mozFullScreenElement: Firefox浏览器使用的属性。document.webkitFullscreenElement: Chrome、Safari和Opera浏览器使用的属性。document.msFullscreenElement: IE和Edge浏览器使用的属性。
如果其中任何一个属性返回一个元素(即,一个元素正在全屏显示),则该函数返回true,表示当前处于全屏模式。否则,返回false。
全屏模式下的样式调整技巧
在全屏模式下,可能需要对页面样式进行调整,以适应更大的屏幕空间或提供更好的用户体验。可以使用CSS和JavaScript来实现这些调整。
- CSS媒体查询: 可以使用CSS媒体查询来检测全屏状态,并应用相应的样式。但是,这种方法依赖于浏览器是否正确地报告全屏状态,并且可能不够可靠。
/* 全屏模式下的样式 */
@media (display-mode: fullscreen) {
body {
font-size: 1.2em; /* 增大字体 */
/* 其他样式调整 */
}
}- JavaScript动态调整样式: 使用JavaScript监听全屏状态变化事件,并在进入或退出全屏时动态地修改元素的样式。这种方法更加灵活和可靠。
document.addEventListener('fullscreenchange', function() {
if (isFullscreen()) {
// 进入全屏模式
document.body.classList.add('fullscreen-mode');
} else {
// 退出全屏模式
document.body.classList.remove('fullscreen-mode');
}
});然后,在CSS中定义.fullscreen-mode类的样式:
.fullscreen-mode {
font-size: 1.2em; /* 增大字体 */
/* 其他样式调整 */
}- 使用CSS变量: 结合JavaScript和CSS变量,可以更方便地控制全屏模式下的样式。
document.addEventListener('fullscreenchange', function() {
if (isFullscreen()) {
document.documentElement.style.setProperty('--fullscreen-font-size', '1.2em');
} else {
document.documentElement.style.setProperty('--fullscreen-font-size', '1em');
}
});然后在CSS中使用CSS变量:
body {
font-size: var(--fullscreen-font-size, 1em); /* 默认字体大小为 1em */
}全屏API的安全性考虑,如何避免恶意全屏?
全屏API的安全性主要涉及避免恶意网站滥用全屏功能,例如,强制用户进入全屏模式,并在全屏模式下显示欺骗性内容。为了防止这种情况,浏览器通常会采取以下措施:
用户许可: 浏览器通常要求用户明确许可才能进入全屏模式。例如,只有在用户点击了页面上的某个元素后,才能调用
requestFullscreen方法。未经用户交互,无法自动进入全屏模式。全屏指示器: 浏览器通常会在全屏模式下显示一个指示器(例如,一个小的图标或消息),告知用户当前页面处于全屏状态。这可以帮助用户识别恶意全屏,并及时退出。
键盘快捷键: 浏览器通常提供一个键盘快捷键(例如,
Esc键),允许用户随时退出全屏模式。权限策略(Permissions Policy): 现代浏览器支持使用权限策略来控制全屏API的使用。通过设置
fullscreen策略,可以限制哪些域或iframe可以请求全屏。
以下是一些建议,可以帮助开发者在使用全屏API时遵守安全最佳实践:
- 仅在必要时使用全屏: 避免不必要地使用全屏功能。只有在用户明确需要全屏体验时,才应该请求全屏。
- 提供清晰的退出全屏方式: 确保用户可以轻松地退出全屏模式。可以在全屏模式下显示一个“退出全屏”按钮,或者告知用户可以使用
Esc键退出。 - 避免在全屏模式下显示欺骗性内容: 确保在全屏模式下显示的内容是真实和可信的。避免使用欺骗性的标题、图标或消息,以免误导用户。
- 使用HTTPS: 确保网站使用HTTPS协议,以防止中间人攻击。中间人攻击者可能会篡改页面内容,并在全屏模式下显示恶意内容。
JS如何判断当前浏览器是否支持全屏API?
要判断当前浏览器是否支持全屏API,可以通过检查document对象和Element.prototype对象上是否存在相关的属性和方法。由于不同浏览器可能使用不同的前缀,因此需要检查多个属性和方法。
以下是一个示例函数,可以用来检测全屏API的支持情况:
function isFullscreenAPISupported() {
return (
'fullscreenEnabled' in document ||
'mozFullScreenEnabled' in document ||
'webkitFullscreenEnabled' in document ||
'msFullscreenEnabled' in document &&
'requestFullscreen' in document.documentElement ||
'mozRequestFullScreen' in document.documentElement ||
'webkitRequestFullscreen' in document.documentElement ||
'msRequestFullscreen' in document.documentElement
);
}
// 使用示例
if (isFullscreenAPISupported()) {
console.log('当前浏览器支持全屏API');
} else {
console.log('当前浏览器不支持全屏API');
}这个函数检查了以下属性和方法:
document.fullscreenEnabled、document.mozFullScreenEnabled、document.webkitFullscreenEnabled、document.msFullscreenEnabled: 这些属性指示浏览器是否允许全屏模式。document.documentElement.requestFullscreen、document.documentElement.mozRequestFullScreen、document.documentElement.webkitRequestFullscreen、document.documentElement.msRequestFullscreen: 这些方法用于请求全屏模式。
如果以上任何一个属性或方法存在,则该函数返回true,表示当前浏览器支持全屏API。否则,返回false。
本篇关于《JS监听全屏变化的5个事件详解》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!
Vue.js双向数据绑定原理解析
- 上一篇
- Vue.js双向数据绑定原理解析
- 下一篇
- Python中sum的用法及功能详解
-
- 文章 · 前端 | 4分钟前 |
- CSSGrid快速定义行列与gap技巧
- 101浏览 收藏
-
- 文章 · 前端 | 4分钟前 |
- 获取TinySlider最左侧幻灯片索引方法
- 197浏览 收藏
-
- 文章 · 前端 | 23分钟前 |
- WebCryptoAPI加密解密全解析
- 220浏览 收藏
-
- 文章 · 前端 | 42分钟前 |
- CSScolor-mix函数详解与使用技巧
- 283浏览 收藏
-
- 文章 · 前端 | 1小时前 | Chrome开发者工具 堆快照 JavaScript内存泄漏 引用关系 分离DOM节点
- JavaScript内存泄漏分析及堆快照使用技巧
- 476浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- 网页转PDF无库方案全解析
- 266浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- CSS响应式侧边栏实现方法
- 314浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- ES6类处理嵌套API数据教程
- 123浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- JavaScript迭代器模式:自定义遍历方法
- 262浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3203次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3416次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3446次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4554次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3824次使用
-
- JavaScript函数定义及示例详解
- 2025-05-11 502浏览
-
- 优化用户界面体验的秘密武器:CSS开发项目经验大揭秘
- 2023-11-03 501浏览
-
- 使用微信小程序实现图片轮播特效
- 2023-11-21 501浏览
-
- 解析sessionStorage的存储能力与限制
- 2024-01-11 501浏览
-
- 探索冒泡活动对于团队合作的推动力
- 2024-01-13 501浏览

