news 2026/6/22 19:57:14

《uni-app跨平台开发完全指南》- 13 -获取设备信息

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
《uni-app跨平台开发完全指南》- 13 -获取设备信息

前言

大家好,今天我们聊一个看似简单、实则至关重要的技术话题——如何获取和利用设备信息。在移动应用开发中,许多令人头疼的适配问题,其根源往往就在设备信息的处理上。今天,我们就来一起聊聊这个话题。

一、系统信息

1.1 同步vs异步

很多人都知道用uni.getSystemInfo(),但其实这里有个性能坑:

// 不推荐:每次都调异步APIasyncfunctiongetDeviceInfo(){constinfo=awaituni.getSystemInfo()returninfo}// 推荐:同步获取+缓存letcachedInfo=nullfunctiongetSystemInfo(){if(!cachedInfo){// 首次使用同步API,避免Promise开销cachedInfo=uni.getSystemInfoSync()}returncachedInfo}

为什么同步更好?

  • 无Promise开销,避免微任务队列调度
  • 不用await
  • 应用启动时就应该获取

但同步API有个坑:在极少数情况下可能会阻塞UI。建议:

  • 应用启动时用同步
  • 运行时变化用异步监听

1.2 专业术语解释

constsystemInfo=uni.getSystemInfoSync()// 一下6个字段比较重要:constessentialFields={// 1. 设备识别platform:systemInfo.platform,// "android" | "ios" | "web"model:systemInfo.model,// 具体型号,如"iPhone 13 Pro"// 2. 屏幕信息pixelRatio:systemInfo.pixelRatio,// 设备像素比screenWidth:systemInfo.screenWidth,// 物理像素宽度windowWidth:systemInfo.windowWidth,// 可用宽度// 3. 刘海屏-安全区域safeArea:systemInfo.safeArea,// 安全区域坐标statusBarHeight:systemInfo.statusBarHeight// 状态栏高度}

特别说明一下pixelRatio这个字段,很多新手会忽略它:

像素比的意义:

// 根据像素比加载合适图片functiongetImageUrl(baseUrl,pixelRatio){if(pixelRatio>=3)return`${baseUrl}@3x.png`if(pixelRatio>=2)return`${baseUrl}@2x.png`return`${baseUrl}.png`}// 计算Canvas绘制尺寸functiongetCanvasSize(designSize,pixelRatio){return{width:designSize.width*pixelRatio,height:designSize.height*pixelRatio,styleWidth:designSize.width,styleHeight:designSize.height}}

1.3 平台差异处理

uni-app号称"一套代码,多端运行",但现实是不同平台确实存在差异:

// Platform适配工具类classPlatformAdapter{staticgetStatusBarHeight(){constinfo=uni.getSystemInfoSync()// iOS和Android的状态栏高度if(info.platform==='ios'){// iOS:iPhone X以上有刘海constisNotchScreen=this.isNotchScreen(info)returnisNotchScreen?44:20}elseif(info.platform==='android'){// Android:通常比iOS高,且版本差异大constversion=parseFloat(info.system.split(' ')[1])||0returnversion>=10?28:25}return20// Web端默认}staticisNotchScreen(info){// 判断是否为刘海屏constnotchModels=['iPhone X','iPhone 11','iPhone 12','iPhone 13','iPhone 14','iPhone 15']returnnotchModels.some(model=>info.model.includes(model))}}

二、屏幕适配

2.1 rpx单位

rpx是uni-app的核心创新,让我们深入了解一下rpx吧。

// rpx转换原理functionrpx2px(rpx,windowWidth=375){// 1rpx = windowWidth / 750return(rpx*windowWidth)/750}// 注意事项constdesignWidth=750constdeviceWidth=uni.getSystemInfoSync().windowWidth// 按钮宽度是200rpxconstbuttonDesignWidth=200// 在任何设备上,实际宽度都是:constactualWidth=(buttonDesignWidth/designWidth)*deviceWidth

rpx的好处在于:

  • 750rpx对应设计稿750px
  • 所有元素按屏幕宽度等比缩放
  • 框架自动处理转换

rpx局限性:

  • 不适合需要固定尺寸的场景(如1px边框)
  • 在大屏设备上可能过度拉伸
  • 图片使用rpx需要配合mode="widthFix"

2.2 适配安全区域

随着全面屏普及,安全区域适配成了必修课:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 8:17:05

从入门到精通,R Shiny多用户权限管理系统搭建全记录

第一章:R Shiny多模态用户权限系统概述在构建企业级数据可视化应用时,R Shiny 提供了强大的交互能力,但默认情况下缺乏对用户身份认证与权限控制的内置支持。为满足不同角色对数据访问、操作和界面展示的差异化需求,需设计一套多模…

作者头像 李华
网站建设 2026/6/22 5:49:18

Dify版本回滚从入门到精通:一套被验证的标准化操作流程

第一章:Dify工作流版本回滚的核心概念在Dify平台中,工作流版本回滚是一项关键的运维能力,允许开发者在部署新版本后遇到异常时,快速恢复至先前稳定的状态。该机制依赖于版本控制系统与部署流水线的深度集成,确保每一次…

作者头像 李华
网站建设 2026/6/21 21:36:39

Frdbio®小鼠抗体纯化试剂盒

产品介绍:Frdbio 小鼠抗体纯化试剂盒用于纯化小鼠血清,腹水和含有鼠源抗体的制品;本试剂盒配备了纯化小鼠抗体所必需预装柱及核心试剂。本试剂盒中预装柱的填料为Protein G Beads 4FF。主要优势如下:本蛋白纯化试剂特点: Protein G Beads 4F…

作者头像 李华
网站建设 2026/6/23 5:21:55

告别冗余加载:构建高效量子计算运行时环境的6个不可忽视步骤

第一章:量子计算镜像的依赖精简在构建面向量子计算模拟器的容器化运行环境时,镜像体积与依赖复杂度直接影响部署效率和安全性。通过精简不必要的系统库和开发工具链,可以显著提升镜像启动速度并降低攻击面。依赖分析与最小化策略 采用静态分析…

作者头像 李华
网站建设 2026/6/23 6:29:26

Agent服务扩展难题,如何在Docker Compose中实现无缝横向扩容?

第一章:Agent服务扩展难题,如何在Docker Compose中实现无缝横向扩容?在微服务架构中,Agent类服务常用于采集日志、监控指标或执行远程指令。随着业务规模增长,单实例Agent难以应对高并发任务,亟需通过横向扩…

作者头像 李华
网站建设 2026/6/23 11:29:42

PageAdmin:为企业政务提供产品及解决方案

PageAdmin专注于网站内容管理系统、SSO单点登录、统一身份认证平台及低代码平台的研发,凭借成熟的技术体系与丰富的实践经验,致力于为各类组织的网站建设和统一数字化信息平台搭建提供企业级解决方案,助力企业高效推进数字化转型。一、核心产…

作者头像 李华