0

0

CSS伪类:fullscreen应用_进入全屏模式后的样式定制

P粉602998670

P粉602998670

发布时间:2026-02-24 14:51:40

|

461人浏览过

|

来源于php中文网

原创

:fullscreen伪类仅在元素通过requestfullscreen()进入全屏时生效,需用户手势触发、作用于块级元素,且仅匹配直接全屏元素;子元素需用class控制,退出后须清理内联样式和transition。

css伪类:fullscreen应用_进入全屏模式后的样式定制

fullscreen伪类不生效?检查是否在全屏上下文中使用

浏览器只在元素真正处于全屏状态(即通过 Element.requestFullscreen() 进入)时,才匹配 :fullscreen 伪类。直接写 CSS 却没调用 JS 全屏 API,样式必然不会触发。

常见错误现象::fullscreen 规则写了但颜色/尺寸没变;控制台无报错,开发者工具里也看不到该规则被应用。

  • 必须先调用 element.requestFullscreen()(注意不同浏览器前缀已基本废弃,无需 webkitRequestFullscreen 等)
  • 不能对 bodyhtml 直接调用 —— 大多数浏览器会拒绝,需作用于一个可渲染的块级元素(如 divvideo
  • 用户手势触发是硬性要求:必须在 clickkeydown 等用户交互事件回调中调用,否则抛出 TypeError: Document not active 或静默失败

Chrome/Firefox/Safari 样式差异大?用 :fullscreen 做统一入口,再按需覆盖

各浏览器对全屏元素的默认样式处理不一致:Firefox 会把全屏元素置顶并拉满视口,Chrome 默认加黑边框,Safari 可能保留滚动条或忽略某些 position 声明。

正确做法是把 :fullscreen 当作「进入全屏」的统一钩子,再在里面重置关键样式:

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

外贸多语言保健品化妆品独立站源码(内置ai智能翻译)2.0.7
外贸多语言保健品化妆品独立站源码(内置ai智能翻译)2.0.7

这款 AI 智能翻译外贸多语言保健品化妆品独立站源码是zancms专为外贸化妆品企业量身定制。它由 zancms 外贸独立站系统 基于化妆品出口企业的独特需求进行研发设计,对各类智能产品企业的出口业务拓展同样大有裨益。其具备显著的语言优势,采用英文界面呈现,且内置智能 AI 翻译功能,在获得商业授权后更可开启多语言模式,充分满足不同地区用户的语言需求,并且整个网站的架构与布局完全依照国外用户的阅读

下载
div.fullscreen-target:fullscreen {
  width: 100vw;
  height: 100vh;
  margin: 0;
  border: none;
  background: black;
  object-fit: contain; /* 对 video/img 很关键 */
}
  • :fullscreen 在 Safari 中需配合 -webkit-:fullscreen 前缀(仅旧版 Safari 15.4 及之前需要,新版已支持无前缀)
  • 不要依赖 display: flex:fullscreen 内居中 —— 某些版本 Firefox 会忽略,改用 position: absolute + inset: 0
  • 字体大小缩放问题:iOS Safari 全屏后可能放大文本,加 text-size-adjust: none 抑制

想让子元素也响应全屏状态?别嵌套 :fullscreen,用属性选择器或 JS 切换 class

:fullscreen 只匹配**直接进入全屏的那个元素**,它的子元素不会自动获得该伪类。试图写 div:fullscreen span 是无效的 —— 浏览器根本不匹配。

真实需求往往是「全屏时,整个播放器区域隐藏控制栏、放大视频」,这时得换思路:

  • 在调用 requestFullscreen() 后,同步给父容器加 class,比如 player--is-fullscreen
  • 或者监听 fullscreenchange 事件,在 document 上判断 document.fullscreenElement 是否为你的目标元素,再切换 class
  • 避免用 :fullscreen 控制子组件显隐,CSS 里写 .player--is-fullscreen .controls { display: none; } 更可靠

退出全屏后样式没恢复?记得清理内联样式和过渡残留

全屏退出时,浏览器会自动移除 :fullscreen 匹配,但如果你在全屏状态下通过 JS 给元素加了 style.width = '100vw' 这类内联样式,退出后它还在,导致布局错乱。

还有个隐蔽坑:用 transition 动画进/出全屏,退出瞬间若未清除 transition 属性,可能卡在中间态或触发意外重绘。

  • 监听 fullscreenchange 事件,在 document.fullscreenElement === null 时,手动清空关键内联样式:el.style.width = ''el.style.height = ''
  • 全屏相关 transition 建议写在 :fullscreen 规则内,而不是基础选择器里,避免退出后仍生效
  • 部分安卓 WebView(如微信内置)退出全屏后 document.fullscreenElement 延迟归 null,可用 setTimeout(..., 0) 做兜底检测

全屏样式看似简单,但跨浏览器行为差异、JS/CSS 协同时机、退出状态清理这三点,最容易漏掉。尤其是 document.fullscreenElement 的存在与否,得在每个关键路径里显式判断,不能靠伪类自动推导。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

982

2023.08.11

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

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

801

2023.11.06

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

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

246

2023.09.22

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

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

866

2024.03.01

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

687

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

22

2025.12.06

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

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

524

2023.06.20

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

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

474

2023.07.28

苹果官网入口与在线访问指南_中国站点快速直达与iPhone查看方法
苹果官网入口与在线访问指南_中国站点快速直达与iPhone查看方法

本专题汇总苹果官网最新可用入口及中国站点访问方式,涵盖官网直达链接、iPhone官方页面查看方法与常见访问说明,帮助用户快速进入苹果官方网站,便捷了解产品信息与官方服务。

7

2026.02.24

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.4万人学习

CSS教程
CSS教程

共754课时 | 35.7万人学习

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

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