防止电脑息屏 html

防止电脑息屏 html

java 复制代码
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>防息屏+防重复点击方案</title>
    <!-- NoSleep.js 用于兼容旧版浏览器 -->
    <script src="https://cdn.jsdelivr.net/npm/nosleep.js@0.12.0/dist/NoSleep.min.js"></script>
</head>
<body>
    <button id="startBtn">启动防息屏</button>
    <button id="timerBtn">测试按钮(防重复点击)</button>

<script>
// 第一部分:防息屏核心逻辑(兼容多浏览器)
let wakeLock = null;
let noSleep = new NoSleep();
let isIE = /*@cc_on!@*/false || !!document.documentMode; // IE检测[10]

// 现代浏览器方案
async function modernWakeLock() {
    if ('wakeLock' in navigator) {
        try {
            wakeLock = await navigator.wakeLock.request('screen');
            // 监听页面可见性变化
            document.addEventListener('visibilitychange', async () => {
                if (document.visibilityState === 'visible' && !wakeLock) {
                    wakeLock = await navigator.wakeLock.request('screen');
                }
            });
        } catch(err) {
            console.log('Wake Lock API不可用,回退到NoSleep.js');
            noSleep.enable(); // 自动启用备选方案[2][9]
        }
    } else {
        noSleep.enable();
    }
}

// IE浏览器方案
function IEWakeLock() {
    if(isIE && window.ActiveXObject) {
        try {
            const objWs = new ActiveXObject("Wscript.Shell");
            setInterval(() => objWs.SendKeys("{SCROLLLOCK}"), 60000);
        } catch(e) {
            alert("请启用ActiveX控件!");
        }
    }
}

// 第二部分:防重复点击逻辑(通用方案)
let clickTimer = null;
document.getElementById('timerBtn').addEventListener('click', function() {
    const btn = this;
    btn.disabled = true;
    btn.textContent = `请等待(30秒)`;
    
    clickTimer = setInterval(() => {
        const remain = parseInt(btn.textContent.match(/\d+/)[0]) - 1;
        btn.textContent = remain > 0 ? `请等待(${remain}秒)` : "测试按钮";
        
        if(remain <= 0) {
            clearInterval(clickTimer);
            btn.disabled = false;
        }
    }, 1000);
});

// 第三部分:启动逻辑(需用户交互)
document.getElementById('startBtn').addEventListener('click', function() {
    if(isIE) {
        IEWakeLock();
    } else {
        modernWakeLock();
        // 尝试自动进入全屏模式
        if(document.documentElement.requestFullscreen) {
            document.documentElement.requestFullscreen();
        }
    }
    this.disabled = true;
    this.textContent = "防息屏已激活";
});

// 第四部分:安全释放资源
window.addEventListener('beforeunload', () => {
    if(wakeLock) wakeLock.release();
    noSleep.disable();
    clearInterval(clickTimer);
});
</script>

</body>
</html>
相关推荐
拉不动的猪1 小时前
前端小白之 CSS弹性布局基础使用规范案例讲解
前端·javascript·css
伍哥的传说1 小时前
React强大且灵活hooks库——ahooks入门实践之开发调试类hook(dev)详解
前端·javascript·react.js·ecmascript·hooks·react-hooks·ahooks
界面开发小八哥1 小时前
界面控件Kendo UI for Angular 2025 Q2新版亮点 - 增强跨设备的无缝体验
前端·ui·界面控件·kendo ui·angular.js
枷锁—sha2 小时前
从零掌握XML与DTD实体:原理、XXE漏洞攻防
xml·前端·网络·chrome·web安全·网络安全
F2E_Zhangmo2 小时前
基于cornerstone3D的dicom影像浏览器 第二章,初始化页面结构
前端·javascript·vue·cornerstone3d·cornerstonejs
代码的余温3 小时前
如何区别HTML和HTML5?
前端·html·html5
天下无贼!3 小时前
【样式效果】纯CSS从零到一实现动态彩色背景效果
前端·css
DoraBigHead3 小时前
手写 `new`、`call`、`apply`、`bind` + V8 函数调用机制解密
前端·javascript·面试
_pengliang3 小时前
css 音频波浪动画-小程序\PC可用
前端·css·小程序
ai小鬼头3 小时前
AIStarter教你快速打包GPT-SoVITS-v2,解锁AI应用市场新玩法
前端·后端·github