javascript技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript技巧 > JavaScript判断设备类型

JavaScript前端实现判断登录设备是移动端还是PC

作者:拉不动的猪

这篇文章主要为大家详细介绍了JavaScript前端如何实现判断登录设备是移动端还是PC,文中的示例代码讲解详细,有需要的小伙伴可以参考下

原生 JS 判断设备类型方法

可通过以下两种主流方案实现设备类型检测:

‌方案一:基于 navigator.userAgent 的 User Agent 检测‌

实现代码‌:

function isMobileDevice() {
  const ua = navigator.userAgent || navigator.vendor || window.opera;
  const mobileRegex = /android|iphone|ipad|ipod|blackberry|iemobile|opera mini|mobile|windows phone|phone|webos|kindle|tablet/i;
  return mobileRegex.test(ua.toLowerCase());
}

逻辑说明‌:

!!!接下来是方案二,方案二不太建议使用,因为三折叠可能不止768

‌方案二:结合屏幕分辨率与 User Agent 检测(增强版) ‌

实现代码‌:

function detectDeviceType() {
  const ua = navigator.userAgent.toLowerCase();
  const isMobileUA = /mobile|android|iphone|ipad|ipod|windows phone|phone|webos/i.test(ua);
  const isSmallScreen = window.innerWidth <= 768;
  return isMobileUA || isSmallScreen ? 'mobile' : 'pc';
}

逻辑说明‌:

‌注意事项

User Agent 的局限性‌:部分浏览器可能伪造 UA(如 Chrome 移动端模拟 PC 模式)‌。

平板设备处理‌:若需区分平板与手机,需额外增加关键词(如 ipadtablet)‌。

动态响应式场景‌:建议结合 CSS 媒体查询实现布局适配,而非仅依赖 JS 检测‌。

‌代码调用示例

if (isMobileDevice()) {
  console.log("当前设备为手机/平板");
} else {
  console.log("当前设备为 PC");
}

‌1. 基于 navigator.userAgent 的插件方案‌

推荐插件‌:mobile-detect.jsplatform.js实现逻辑‌:

代码示例(以 mobile-detect.js 为例) ‌:

// 引入插件
import MobileDetect from 'mobile-detect';

// 初始化检测器
const md = new MobileDetect(navigator.userAgent);

// 判断设备类型
if (md.mobile()) {
  console.log("移动端登录设备(手机/平板)");
} else if (md.tablet()) {
  console.log("平板设备");
} else {
  console.log("PC 端设备");
}

‌2. 结合屏幕分辨率的增强方案‌

推荐插件‌:react-device-detect(适用于 React 项目)

实现逻辑‌:

代码示例‌:

import { isMobile } from 'react-device-detect';

if (isMobile) {
  console.log("移动端登录设备");
} else {
  console.log("PC 端登录设备");
}

注意事项

‌推荐插件对比‌

插件适用场景优点
mobile-detect.js需要细分设备类型(手机/平板)支持 5000+ 设备类型识别
react-device-detectReact 项目集成简单,支持响应式设计
platform.js轻量级检测(仅区分 PC/移动端)体积小(< 5KB)

到此这篇关于JavaScript前端实现判断登录设备是移动端还是PC的文章就介绍到这了,更多相关JavaScript判断设备类型内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文