0

0

CSS如何获取全屏状态下的元素_通过:fullscreen伪类实现

P粉602998670

P粉602998670

发布时间:2026-03-14 14:21:11

|

770人浏览过

|

来源于php中文网

原创

:fullscreen仅匹配JS调用requestFullscreen()进入原生全屏的元素,不响应F11或CSS模拟全屏;需配合fullscreenchange事件监听状态,且Safari/iOS/移动端兼容性差,不可用于关键功能。

css如何获取全屏状态下的元素_通过:fullscreen伪类实现

怎么用 :fullscreen 选中全屏元素

直接写 :fullscreen 就行,但它只匹配当前处于原生全屏模式(由 Element.requestFullscreen() 触发)的元素,不是所有“看起来占满屏幕”的元素都算。比如用 CSS width: 100vw; height: 100vh 模拟的“伪全屏”,:fullscreen 完全不生效。

常见错误是以为它能捕获 F11 全屏浏览器窗口——不能。:fullscreen 只响应 JS 主动调用的全屏 API,和浏览器 UI 全屏无关。

  • :fullscreen 是标准写法,现代浏览器(Chrome 65+、Firefox 64+、Safari 15.4+)已支持,无需前缀
  • 旧版浏览器需用带前缀版本::fullscreen(标准)、:-webkit-full-screen:-moz-fullscreen:-ms-fullscreen,建议同时写全
  • 它只能用于选择器开头或中间,不能单独用(比如 div:fullscreen ✅,:fullscreen .btn ❌)

:fullscreen 的样式作用范围和继承限制

一旦某个元素进入全屏,:fullscreen 会精准匹配它本身,但它的子元素不会自动获得该伪类——除非你显式写 div:fullscreen span 这样的组合选择器。

关键限制:全屏状态下,浏览器会重置大部分 inherited 样式(比如 font-sizecolor),但 :fullscreen 规则里声明的样式仍有效。这意味着你不能依赖父级设置的 line-heightmargin,得在 :fullscreen 块里重新声明。

立即学习前端免费学习笔记(深入)”;

Napkin AI
Napkin AI

Napkin AI 可以将您的文本转换为图表、流程图、信息图、思维导图视觉效果,以便快速有效地分享您的想法。

下载
  • 全屏后 body 默认被设为 overflow: hidden,滚动条消失,但这是 UA 样式,不是你的 CSS 控制的
  • :fullscreen 内无法用 position: fixed 实现真正固定定位(部分浏览器会降级为 absolute
  • 如果元素有 transform,全屏时可能触发渲染异常,建议加 will-change: transform 预防

监听全屏状态变化比纯 CSS 更可靠

仅靠 :fullscreen 无法知道“什么时候进/出全屏”,也无法做逻辑判断(比如记录用户行为、关闭弹窗)。必须配合 JS 事件。

真实场景中,CSS 伪类只是视觉补丁,核心状态管理得靠 JS:

  • 监听 document.onfullscreenchange —— 进出全屏都会触发
  • 检查 document.fullscreenElement 是否为 null 来判断当前是否有元素全屏
  • 注意事件名没有 “s”:fullscreenchange,不是 fullscreenchanged
  • 调用 requestFullscreen() 可能被拒绝(比如非用户手势触发、iframe 无 allow="fullscreen"),要 catch Promise reject

示例判断逻辑:

document.addEventListener('fullscreenchange', () => {
  if (document.fullscreenElement) {
    console.log('进入全屏:', document.fullscreenElement);
  } else {
    console.log('退出全屏');
  }
});

兼容性坑:Safari 和移动端特别容易掉链子

Safari(尤其 iOS)对 :fullscreen 支持很保守:它要求元素必须是 <video> 或显式设置了 webkit-playsinline 的媒体元素,否则即使调用了 requestFullscreen(),伪类也不匹配。

移动端 WebView(如微信内置浏览器)基本不支持原生全屏 API,:fullscreen 彻底失效,别指望它。

  • iOS Safari 中,document.fullscreenEnabled 永远是 false,但 <video> 仍可触发全屏(走的是系统视频控件,不是标准 API)
  • Android Chrome 从 117 开始默认禁用非 <video> 元素的全屏(需手动开启 chrome://flags/#enable-experimental-web-platform-features)
  • 不要用 :fullscreen 做关键功能兜底,比如“全屏时才显示按钮”——用户可能根本进不去全屏
全屏是个浏览器权限敏感区,:fullscreen 看似简单,但实际生效高度依赖上下文:是否由用户操作触发、元素类型、平台、甚至当前页面是否在 iframe 里。真要用,先跑通 requestFullscreen() + fullscreenchange 这一套,再加 CSS 修饰,别倒过来。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1065

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

845

2023.11.06

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

531

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6259

2023.08.17

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号