js如何检测当前页面是否以全屏模式显示?

"```js

javascript 复制代码
function isFullScreen() {
  return (
    (document.fullscreenElement && document.fullscreenElement !== null) ||
    (document.webkitFullscreenElement && document.webkitFullscreenElement !== null) ||
    (document.mozFullScreenElement && document.mozFullScreenElement !== null) ||
    (document.msFullscreenElement && document.msFullscreenElement !== null)
  );
}

上述代码是用于检测当前页面是否以全屏模式显示的 JavaScript 函数。它通过检查不同浏览器的全屏属性来确定是否处于全屏模式。

函数内部使用了四个属性来检测全屏状态:

  • document.fullscreenElement:标准 API,在全屏模式下返回当前全屏元素,否则返回 null。
  • document.webkitFullscreenElement:Webkit 内核浏览器 API,在全屏模式下返回当前全屏元素,否则返回 null。
  • document.mozFullScreenElement:Firefox 浏览器 API,在全屏模式下返回当前全屏元素,否则返回 null。
  • document.msFullscreenElement:IE 浏览器 API,在全屏模式下返回当前全屏元素,否则返回 null。

函数通过逻辑运算符 || 来判断是否有其中一个属性不为 null,即可确定页面是否处于全屏模式。

调用该函数可以返回一个布尔值,true 表示页面以全屏模式显示,false 表示页面不是全屏模式。

以下是使用示例:

javascript 复制代码
if (isFullScreen()) {
  console.log(\"页面处于全屏模式\");
} else {
  console.log(\"页面不是全屏模式\");
}

请注意,全屏模式可能会受到浏览器的限制,比如需要用户操作才能进入全屏模式,或者在某些情况下无法退出全屏。因此,在实际使用中,需要根据具体需求和浏览器的支持情况进行测试和处理。

" 复制代码
相关推荐
ywf12152 小时前
前端的dist包放到后端springboot项目下一起打包
前端·spring boot·后端
恋猫de小郭2 小时前
2026,Android Compose 终于支持 Hot Reload 了,但是收费
android·前端·flutter
hpoenixf8 小时前
2026 年前端面试问什么
前端·面试
还是大剑师兰特8 小时前
Vue3 中的 defineExpose 完全指南
前端·javascript·vue.js
泯泷8 小时前
阶段一:从 0 看懂 JSVMP 架构,先在脑子里搭出一台最小 JSVM
前端·javascript·架构
mengchanmian9 小时前
前端node常用配置
前端
华洛9 小时前
利好打工人,openclaw不是企业提效工具,而是个人助理
前端·javascript·产品经理
xkxnq9 小时前
第六阶段:Vue生态高级整合与优化(第93天)Element Plus进阶:自定义主题(变量覆盖)+ 全局配置与组件按需加载优化
前端·javascript·vue.js
A黄俊辉A10 小时前
vue css中 :global的使用
前端·javascript·vue.js
小码哥_常10 小时前
被EdgeToEdge适配折磨疯了,谁懂!
前端