一、业务背景
最近在利用mpvue+ts开发小程序的过程中,由于苹果X等手机会出现底部的按钮,会遮盖掉需要操作的按钮。由于在小程序开发,微信爸爸已经做了对机型的检查,相对与H5的处理来说方便很多了。下面就稍微罗列一下解决方案。
二、实现思路
- 判断机型方法
- 注入全局组件mixin
- 加入全局安全距离css
- 页面上进行class类处理
三、实现过程
1、判断机型方法
小程序的官方文档提供了一个方法wx.getSystemInfo,我们可以利用该方法来对小程序的对应的手机型号进行判断,是否需要加上安全距离。在工具类文件新建safe-area.js文件,编写下面代码,这里返回一个Project,方便取值。
let cache = null; export default function getSafeArea() { return new Promise((resolve, reject) => { if (cache != null) { // 如果有缓存不行行调用 resolve(cache); } else { // 获取系统信息 wx.getSystemInfo({ success: ({ model, screenHeight, statusBarHeight }) => { const iphoneX = /iphone x/i.test(model); const iphoneNew = /iPhone11/i.test(model) && screenHeight === 812; cache = { isIPhoneX: iphoneX || iphoneNew, statusBarHeight }; resolve(cache); }, fail: reject }); } }); }
2、注入全局组件mixin
因为mpvue是具有mixin这个属性的,我们可以利用混入安全距离的处理方法。用法基本跟vue一致。新建mixins.js,注入插件,在这个过程中需要注意一点,就是如果不进行页面类型的判断,会出现如果引用组件也会进行注入该方法。所以需要加入进行判断
Vue.prototype.$isPage = function isPage() { return this.$mp && this.$mp.mpType === 'page' }
在mounted过程中进行处理,可以避免不必要的注入。
import getSafeArea from '../utils/safe-area' let MyPlugin = {}; MyPlugin.install = function (Vue) { // 添加全局方法或属性 Vue.prototype.$isPage = function isPage() { return this.$mp && this.$mp.mpType === 'page' } // 注入组件 Vue.mixin({ data() { return { isIPhoneX: this.isIPhoneX, } }, mounted() { if (this.$isPage()) { getSafeArea().then(({ isIPhoneX, statusBarHeight }) => { this.isIPhoneX = isIPhoneX }); } } }) } export default MyPlugin
在main.js中注册该插件
import MyPlugin from './minxins' Vue.use(MyPlugin)
3、加入全局安全距离css
为了我们不需要在每一个文件进行样式的声明,我们可以在全局样式中写入安全距离的类
.safeArea { padding-bottom: 34px!important; }
4、页面上进行class类处理
处理完以上部分我们可以对页面上需要处理的区域,加入:class="{safeArea: isIPhoneX}"进行修改,例如:
<div class="handle" :class="{safeArea: isIPhoneX}"> <div class="home" @click="goHome"></div> <div class="submit" @click="buy">立即购买</div> </div>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 第五街的士高《印度激情版》3CD [WAV+CUE][2.4G]
- 三国志8重制版哪个武将智力高 三国志8重制版智力武将排行一览
- 三国志8重制版哪个武将好 三国志8重制版武将排行一览
- 三国志8重制版武将图像怎么保存 三国志8重制版武将图像设置方法
- 何方.1990-我不是那种人【林杰唱片】【WAV+CUE】
- 张惠妹.1999-妹力新世纪2CD【丰华】【WAV+CUE】
- 邓丽欣.2006-FANTASY【金牌大风】【WAV+CUE】
- 饭制《黑神话》蜘蛛四妹手办
- 《燕云十六声》回应跑路:年内公测版本完成95%
- 网友发现国内版《双城之战》第二季有删减:亲亲环节没了!
- 邓丽君2024-《漫步人生路》头版限量编号MQA-UHQCD[WAV+CUE]
- SergeProkofievplaysProkofiev[Dutton][FLAC+CUE]
- 永恒英文金曲精选4《TheBestOfEverlastingFavouritesVol.4》[WAV+CUE]
- 群星《国风超有戏 第9期》[320K/MP3][13.63MB]
- 群星《国风超有戏 第9期》[FLAC/分轨][72.56MB]