小程序根据手机机型设置自定义底部导航距离


Posted in Javascript onJune 04, 2019

需求:

iponeX 以上机型,手机底部有弧度,自己写的导航栏会被遮住, 需要判断手机机型,做兼容设置.

解决:

//app.js
App({

 /**
  * 当小程序初始化完成时,会触发 onLaunch(全局只触发一次)
  */
 onLaunch: function() {
  var that = this;
  //获取手机型号
  wx.getSystemInfo({
   success(res) {
    const model = res.model;
    const modelInclude = ["iPhone X", 'iPhone XR', "iPhone XS", "iPhone XS MAX"];
    var flag = false;//是否X以上机型
    for (let i = 0; i < modelInclude.length;i ++){
     //模糊判断是否是modelInclude 中的机型,因为真机上测试显示的model机型信息比较长无法一一精确匹配
     if (model.indexOf(modelInclude[i]) != -1){
      flag = true
     }
    }
    if (flag) {
     that.BOTTOM_DISTANCE = 50;
    }
   }
  })
 },

 /**
  * 当小程序启动,或从后台进入前台显示,会触发 onShow
  */
 onShow: function(options) {

 },

 /**
  * 当小程序从前台进入后台,会触发 onHide
  */
 onHide: function() {

 },

 /**
  * 当小程序发生脚本错误,或者 api 调用失败时,会触发 onError 并带上错误信息
  */
 onError: function(msg) {

 },

 BOTTOM_DISTANCE:0,//iponeX底部需要抬高的距离
})

页面js

const app = getApp();

Page({

 /**
  * 页面的初始数据
  */
 data: {
  bottom: app.BOTTOM_DISTANCE//将app实例中的BOTTOM_DISTANCE转化为页面的data,即可在xml上使用
 },

 /**
  * 生命周期函数--监听页面加载
  */
 onLoad: function(options) {
 },
})

然后设置导航底部padding距离即可;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript设置body高度为浏览器高度的方法
Feb 09 Javascript
JavaScript电子时钟倒计时
Jan 09 Javascript
js仿百度登录页实现拖动窗口效果
Mar 11 Javascript
js实现页面a向页面b传参的方法
May 29 Javascript
JS实现用户注册时获取短信验证码和倒计时功能
Oct 27 Javascript
使用vue.js2.0 + ElementUI开发后台管理系统详细教程(一)
Jan 21 Javascript
JavaScript事件处理程序详解
Sep 19 Javascript
vue获取dom元素注意事项
Dec 28 Javascript
js+html5实现手机九宫格密码解锁功能
Jul 30 Javascript
package.json配置文件构成详解
Aug 27 Javascript
JavaScript 面向对象程序设计详解【类的创建、实例对象、构造函数、原型等】
May 12 Javascript
Node.js web 应用如何封装到Docker容器中
Sep 01 Javascript
js回文数的4种判断方法示例
Jun 04 #Javascript
Vue对象赋值视图不更新问题及解决方法
Jun 03 #Javascript
在 Vue 应用中使用 Netlify 表单功能的方法详解
Jun 03 #Javascript
JavaScript之数组扁平化详解
Jun 03 #Javascript
JavaScript从原型到原型链深入理解
Jun 03 #Javascript
生产制造追溯系统之再说条码打印
Jun 03 #Javascript
VUE安装使用教程详解
Jun 03 #Javascript
You might like
关于PHP中操作MySQL数据库的一些要注意的问题
2006/10/09 PHP
echo(),print(),print_r()之间的区别?
2006/11/19 PHP
学习discuz php 引入文件的方法DISCUZ_ROOT
2009/06/21 PHP
php记录代码执行时间(实现代码)
2013/07/05 PHP
深入理解PHP中的empty和isset函数
2016/05/26 PHP
php设计模式之模板模式实例分析【星际争霸游戏案例】
2020/03/24 PHP
Javascript学习笔记6 prototype的提出
2010/01/11 Javascript
javascript中encodeURI和decodeURI方法使用介绍
2013/05/06 Javascript
js正文内容高亮效果的实现方法
2013/06/30 Javascript
编程语言JavaScript简介
2014/10/16 Javascript
jQuery对象的length属性用法实例
2014/12/27 Javascript
JS中完美兼容各大浏览器的scrolltop方法
2015/04/17 Javascript
浅谈Javascript中的12种DOM节点类型
2016/08/19 Javascript
JS简单实现禁止访问某个页面的方法
2016/09/13 Javascript
PHP实现本地图片上传和验证功能
2017/02/27 Javascript
angular2中router路由跳转navigate的使用与刷新页面问题详解
2017/05/07 Javascript
jQuery实现的页面遮罩层功能示例【测试可用】
2017/10/14 jQuery
vue轻量级框架无法获取到vue对象解决方法
2019/05/12 Javascript
layui实现form表单同时提交数据和文件的代码
2019/10/25 Javascript
JS实现打砖块游戏
2020/02/14 Javascript
nodejs如何在package.json中设置多条启动命令
2020/03/16 NodeJs
python cookielib 登录人人网的实现代码
2012/12/19 Python
Python Web开发模板引擎优缺点总结
2014/05/06 Python
六个窍门助你提高Python运行效率
2015/06/09 Python
python3学习笔记之多进程分布式小例子
2018/02/13 Python
Python爬虫——爬取豆瓣电影Top250代码实例
2019/04/17 Python
python实现银行实战系统
2020/02/26 Python
Python中SQLite如何使用
2020/05/27 Python
Python通过getattr函数获取对象的属性值
2020/10/16 Python
YOOX美国官方网站:全球著名的多品牌时尚网络概念店
2016/09/11 全球购物
三查三看党性分析材料
2014/02/18 职场文书
活动总结模板
2014/05/09 职场文书
个人四风问题对照检查材料
2014/09/26 职场文书
python 如何执行控制台命令与操作剪切板
2021/05/20 Python
vue实现拖拽交换位置
2022/04/07 Vue.js
html原生table实现合并单元格以及合并表头的示例代码
2023/05/07 HTML / CSS