微信小程序 - 设备信息与版本更新

简介: 微信小程序 - 设备信息与版本更新
  • 在微信小程序开发的时候,判断当前设备是否为(Android、iOS、Mac、Windows),获取状态栏高度,导航栏高度,tabBar高度,设备信息参数
  • 在微信小程序开发的时候,微信小程序新版本发布之后,用户使用依然是旧版本,这是因为在微信中有旧版本的缓存,不会及时更新到新版本。要想让用户更新到新版本:
    1、可以通过提示用户在微信中的“发现 - 小程序”入口中将旧版小程序删除,然后再重新搜索并打开该小程序但这种方式的用户体验极差,不推荐。
    2、通过 wx.getUpdateManager() 系统函数实现手动更新,推荐写在小程序主页面的的 onLoad() 事件中,也可以写在别的地方手动触发,推荐。
  • 这里我就把以上几点都封装起来了,存放到 system.js 中,只需要在使用的页面导入即可:
// 获取小程序以及设备信息
function get(success, fail=undefined) {
  // 设备信息
  const info = {
    // 系统设备信息原对象
    info: {},
    // 是否为iOS
    isIOS: false,
    // 是否为iphoneX XR XS...等iOS系统全面屏手机
    isIphoneX: false,
    // 是否为安卓
    isAndroid: false,
    // 是否为Mac
    isMac: false,
    // 是否为Windows
    isWindows: false,
    // 设备像素比 (px 与 rpx 的转换比例, 公式:px * pixelRatio = rpx)
    pixelRatio: 1,
    // 屏幕宽度
    screenWidth: 0,
    screenWidthRPX: 0,
    // 屏幕高度
    screenHeight: 0,
    screenHeightRPX: 0,
    // 状态栏高度
    statusBarHeight: 0,
    statusBarHeightRPX: 0,
    // 导航栏高度(不包括状态栏,单纯的导航栏高度)
    navigationBarHeight: 0,
    navigationBarHeightRPX: 0,
    // 导航栏高度(包括状态栏,整个导航栏高度)
    navigationHeight: 0,
    navigationHeightRPX: 0,
    // 底部TabBar菜单栏高度
    tabBarHeight: 0,
    tabBarHeightRPX: 0
  }
  // 加载系统信息进行更换
  wx.getSystemInfo({
    // 获取成功
    success: (res) => {
      // 右上角菜单胶囊范围
      let menuButtonRect = wx.getMenuButtonBoundingClientRect()
      // 状态栏默认高度
      const statusBarHeight = 20
      // 导航栏默认高度
      const navigationBarHeight = 44
      // TabBar默认高度
      const tabBarHeight = 48
      // 记录原始数据
      info.info = res
      // 是否为iOS
      info.isIOS = (res.system.indexOf('iOS') !== -1)
      // 是否为iOS系统全面屏手机
      if (info.isIOS) {
        // 如果为 iOS 且安全区域上面超过 默认状态栏高度 则为 X 系列
        info.isIphoneX = (res.safeArea.top > statusBarHeight)
      }
      // 是否为安卓
      info.isAndroid = (res.system.indexOf('Android') !== -1)
      // 是否为Mac
      info.isMac = (res.system.indexOf('macOS') !== -1)
      // 是否为Windows
      info.isWindows = (res.system.indexOf('Windows') !== -1)
      // 设备像素比(750 / 屏幕宽度)
      // 系统给成的 res.pixelRatio 值不对,所以使用自己换算出来的比例
      info.pixelRatio = 750 / res.windowWidth
      // 屏幕宽度
      info.screenWidth = res.screenWidth
      // 屏幕宽度 - RPX
      info.screenWidthRPX = info.screenWidth * info.pixelRatio
      // 屏幕高度
      info.screenHeight = res.screenHeight
      // 屏幕高度 - RPX
      info.screenHeightRPX = info.screenHeight * info.pixelRatio
      // 状态栏高度
      info.statusBarHeight = Math.max(res.statusBarHeight, statusBarHeight)
      // 状态栏高度 - RPX
      info.statusBarHeightRPX = info.statusBarHeight * info.pixelRatio
      // 导航栏高度
      const menuBarHeight = (menuButtonRect.top - info.statusBarHeight) * 2 + menuButtonRect.height
      info.navigationBarHeight = Math.max(menuBarHeight, navigationBarHeight)
      // 导航栏高度 - 如果为奇数则转成偶数
      if (info.navigationBarHeight % 2) { info.navigationBarHeight += 1 }
      // 导航栏高度 - RPX
      info.navigationBarHeightRPX = info.navigationBarHeight * info.pixelRatio
      // 导航栏高度
      info.navigationHeight = (info.statusBarHeight + info.navigationBarHeight)
      // 导航栏高度 - RPX
      info.navigationHeightRPX = info.navigationHeight * info.pixelRatio
      // 底部TabBar菜单栏高度
      info.tabBarHeight = Math.max(info.screenHeight - info.navigationHeight - res.windowHeight, tabBarHeight)
      // 底部TabBar菜单栏高度 - 如果为奇数则转成偶数
      if (info.tabBarHeight % 2) { info.tabBarHeight += 1 }
      // 底部TabBar菜单栏高度 - RPX
      info.tabBarHeightRPX = info.tabBarHeight * info.pixelRatio
      // 返回
      if (success) { success(info) }
    },
    // 获取失败
    fail: (err) => {
      if (fail) { fail(err) }
    }
  })
}
// 检查小程序版本并更新
function update(success=undefined, fail=undefined) {
  // 检查是否支持版本更新
  if (wx.canIUse('getUpdateManager')) {
    // 获取版本更新对象
    var updateManager = wx.getUpdateManager()
    // 检测是否有新版本
    updateManager.onCheckForUpdate((res) => {
      // 有新版本
      if (res.hasUpdate) {
        // 更新成功回调
        updateManager.onUpdateReady((res) => {
          // 有回调实现
          if (success) {
            // 自己写提示,返回版本更新对象,方便外部使用
            success(updateManager, res)
          } else {
            // 使用内部更新提示
            wx.showModal({
              title: '更新提示',
              content: '新版本已经准备好,是否重启应用?',
              success: (res) => {
                // 确定重启,在 onUpdateReady 回调中使用 applyUpdate 强制小程序重启使用新版本。
                if (res.confirm) { updateManager.applyUpdate() }
              }
            })
          }
        })
        // 更新失败回调
        updateManager.onUpdateFailed((err) => {
          // 有回调实现
          if (fail) {
            // 自己写提示
            fail(err)
          } else {
            // 使用内部更新提示
            wx.showModal({
              title: '更新提示',
              content: '新版本下载失败,请检查网络!',
              showCancel: false
            })
          }
        })
      } else {
        // 无新版本
      }
    })
  }
}
// 导出使用
module.exports = {
  // 获取小程序以及设备信息
  get,
  // 检查小程序版本并更新
  update
}
  • app.js 文件中使用
// 导入 system.js
const system = require("./utils/system.js")
// 小程序主入口
App({
  // 设备信息存放,设备信息推荐存放到 app.js 文件中作为全局参数使用
  // 然后到每个页面通过 const app = getApp() 获取使用即可 app.systemInfo
  systemInfo: {},
  // 启动函数
  onLaunch: function (options) {
    // 检查版本更新,推荐放这里,也可以放到手动触发的地方调用
    system.update()
    // 获取设备信息
    system.get((info) => {
      // 记录设备信息
      this.systemInfo = info
      // 输出
      console.log('设备信息:', info)
    })
  }
})


相关文章
|
小程序 开发者
【小程序】微信小程序版本更新如何通知用户?
【小程序】微信小程序版本更新如何通知用户?
1240 0
【小程序】微信小程序版本更新如何通知用户?
|
小程序
微信小程序版本更新
微信小程序版本更新
253 0
|
API
微信小程序把玩(三十八)获取设备信息 API
原文:微信小程序把玩(三十八)获取设备信息 API 获取设备信息这里分为四种, 主要属性: 网络信息wx.getNetWorkType, 系统信息wx.
1390 0
|
测试技术
微信快速开发框架(七)--发送客服信息,版本更新至V2.2 代码已更新至github
在V2版本发布的博文中,已经介绍了大多数Api的用法,同时也收到了很多意见,其中发布了几个修正版本,修改了几个bug,在此感谢大家的使用,有了大家的支持,相信快速开发框架会越来越好,也会越来越完善的。 如果您是第一次看到此框架,可以先从以下链接了解下: 一、对微信公众平台开发的消息处理    二...
1116 0
|
5月前
|
监控 前端开发 小程序
陪练,代练,护航,代打小程序源码/前端UNIAPP-VUE2.0开发 后端Thinkphp6管理/具备家政服务的综合型平台
这款APP通过技术创新,将代练、家政、娱乐社交等场景融合,打造“全能型生活服务生态圈”。以代练为切入点,提供模块化代码支持快速搭建平台,结合智能匹配与技能审核机制,拓展家政服务和商业管理功能。技术架构具备高安全性和扩展性,支持多业务复用,如押金冻结、录屏监控等功能跨领域应用。商业模式多元,包括交易抽成、增值服务及广告联名,同时设计跨领域积分体系提升用户粘性,实现生态共生与B端赋能。
410 12
|
8月前
|
移动开发 小程序
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
270 0
|
10月前
|
小程序 前端开发 JavaScript
在线课堂+工具组件小程序uniapp移动端源码
在线课堂+工具组件小程序uniapp移动端源码
195 0
在线课堂+工具组件小程序uniapp移动端源码
|
11月前
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
1701 3
|
11月前
|
小程序 API
微信小程序更新提醒uniapp
在小程序开发中,版本更新至关重要。本方案利用 `uni-app` 的 `uni.getUpdateManager()` API 在启动时检测版本更新,提示用户并提供立即更新选项,自动下载更新内容,并在更新完成后重启小程序以应用新版本。适用于微信小程序,确保用户始终使用最新版本。以下是实现步骤: ### 实现步骤 1. **创建更新方法**:在 `App.vue` 中创建 `updateApp` 方法用于检查小程序是否有新版本。 2. **测试**:添加编译模式并选择成功状态进行模拟测试。
277 0
微信小程序更新提醒uniapp
|
小程序 前端开发 Java
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
JavaDog Chat v1.0.0 是一款基于 SpringBoot、MybatisPlus 和 uniapp 的简易聊天软件,兼容 H5、小程序和 APP,提供丰富的注释和简洁代码,适合初学者。主要功能包括登录注册、消息发送、好友管理及群组交流。
281 0
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目

热门文章

最新文章