codecamp

百度智能小程序 获取菜单按钮布局位置

swan.getMenuButtonBoundingClientRect

基础库 3.20.3 开始支持,低版本需做兼容处理。

解释:获取菜单按钮(右上角胶囊按钮)的布局位置信息。坐标信息以屏幕左上角为原点。Web 态说明: 在 Web 态环境下,不存在右上角菜单按钮,调用该方法会返回一个固定值,仅供参考。

方法参数

返回参数说明

参数类型说明

width

number

宽度,单位:px

height

number

高度,单位:px

top

number

上边界坐标,单位:px

right

number

右边界坐标,单位:px

bottom

number

下边界坐标,单位:px

left

number

左边界坐标,单位:px

示例

代码示例 1: 属性全集 

在开发者工具中打开

<view class="wrap">
    <view class="card-area">  
        <view class="list-area border-bottom" s-for="item in infoList">
            <view class="list-item-key-4">{{item.chineseName}}}</view>
            <view class="list-item-value">{{item.value}}</view>
        </view>        
        <button type="primary" bindtap="getMenuButtonBoundingClientRect">点击获取胶囊布局信息</button>
    </view>
</view>
Page({
    data: {
        result: '',
        infoList: [{
            chineseName: '高度',
            engName: 'height', 
            value: ''
        }, {
            chineseName: '宽度',
            engName: 'width', 
            value: ''
        }, {
            chineseName: '距下',
            engName: 'bottom', 
            value: ''
        }, {
            chineseName: '距左',
            engName: 'left', 
            value: ''
        }, {
            chineseName: '距右',
            engName: 'right', 
            value: ''
        }, {
            chineseName: '距上',
            engName: 'top', 
            value: ''
        }]
    },
    getMenuButtonBoundingClientRect() {
        try {
            const result = swan.getMenuButtonBoundingClientRect();
            console.log('getMenuButtonBoundingClientRect success', result);
            this.updateInfoList(result);
        } catch (err) {
            console.log('getMenuButtonBoundingClientRect fail', err);
        }
    },

    updateInfoList(res) {
        let infoList = this.getData('infoList');
        for (let i = 0; i < infoList.length; ++i) {
            if (res[infoList[i].engName] === '') {
                infoList[i].value = '暂无';
            } else {
                infoList[i].value = res[infoList[i].engName]+ "px";
            }
        }
        this.setData('infoList', infoList);
    }
});

参考示例

参考示例 1: 自定义导航栏

在开发者工具中打开

<view class="status-height" style="height:{{ statusHeight }}px">状态栏</view>
<view class="nav-height" style="height:{{ navHeight }}px">导航栏</view>
Page({
    data: {
        statusHeight: 0,  //状态栏高度
        navHeight: 0      //导航栏高度
    },
    /**
     * 获取状态栏|导航栏高度,
     */
    onLoad() {
        let capsule = swan.getMenuButtonBoundingClientRect() ;
        console.log('胶囊信息是:', capsule);
        swan.getSystemInfo({
            success: res => {
                console.log('navHeight', capsule.height + (capsule.top - res.statusBarHeight) * 2);
                // 与res.navigationBarHeight相同
                console.log('navHeight', res.navigationBarHeight);
                let navHeight = capsule.height + (capsule.top - res.statusBarHeight) * 2;
                // 这里可以实现文字标题与胶囊的中线对齐的需求
                this.setData({
                    statusHeight: res.statusBarHeight,
                    navHeight
                })
            }
        })
    }
});


百度智能小程序 延迟执行
百度智能小程序 创建IntersectionObserver
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

百度智能小程序开发文档

百度智能小程序 组件

百度智能小程序 地图

百度智能小程序 画布

百度智能小程序 API

百度智能小程序 界面

百度智能小程序 关注小程序引导组件

百度智能小程序 自定义组件

百度智能小程序 媒体

百度智能小程序 设备

百度智能小程序 拨打电话

百度智能小程序 内存警报

百度智能小程序 手机联系人

百度智能小程序 用户截屏事件

百度智能小程序 第三方平台

百度智能小程序 开放接口

百度智能小程序 百度收银支付

百度智能小程序 分包预下载

百度智能小程序 数据分析

百度智能小程序 服务端

百度智能小程序 云开发

百度智能小程序 初始化

百度智能小程序 云函数

百度智能小程序 服务端初始化

百度智能小程序 服务器获取上下文

百度智能小程序 服务端云函数

百度智能小程序 开发教程

百度智能小程序 功能开发

百度智能小程序 基本原理

百度智能小程序 小程序自动化

百度智能小程序 视频教程

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }