直接用 navigator.userAgent 判断移动端,核心是匹配 Android|iPhone|iPad|iPod|Mobile 等关键词,兼顾 iPad 特殊性(含 Macintosh 但支持触控),不用于安全场景,建议辅以 ontouchstart 或视口宽度验证。
直接用 navigator.userAgent 判断移动端,核心是匹配常见移动设备关键词,再据此执行不同逻辑——不依赖第三方库,轻量、可靠、浏览器原生支持。
主流移动设备的 UA 中通常包含以下关键词之一:
推荐正则写法:/Android|iPhone|iPad|iPod|Mobile/i。比只写 /(Android|iPhone)/i 更全面,避免漏判。
以下代码可直接运行,兼容所有现代浏览器:
const ua = navigator.userAgent;const isMobile = /Android|iPhone|iPad|iPod|Mobile/i.test(ua);if (isMobile) { console.log("移动端:启用触摸优化、隐藏非必要控件、加载轻量资源"); // 比如:移除 hover 效果、绑定 touchstart 替代 click document.body.classList.add('mobile');} else { console.log("PC端:显示完整导航、启用键盘快捷键、加载高清图"); document.body.classList.add('desktop');}
iPad 在较新系统(iOS 13+)中 UA 默认不含 Mobile,但仍是典型移动端。若业务需对 iPad 单独处理(比如用 PC 版布局),可加一层排除:
/iPad/i.test(ua)
!/Macintosh/i.test(ua) 排除 macOS Safari 误判(因 iPad UA 也含 Macintosh)/iPad/i.test(ua) && /Macintosh/i.test(ua) && 'ontouchend' in document(利用触控能力佐证)UA 字符串可被用户或调试工具修改,因此:
'ontouchstart' in window 或 window.innerWidth < 768
),如需区分,可扩展正则,但一般归入移动端即可