Uniapp自动调整元素高度

获取设备的像素

如果你想让元素的高度相对于整个屏幕的高度占用一定的比例,可以通过获取屏幕的高度,然后计算出你想要的比例来设置元素的高度。以下是如何实现的示例:

vue 复制代码
<script setup>
import { ref, onMounted } from 'vue';

// 定义一个响应式变量来存储计算后的高度
const contextBoxHeight = ref('auto');

onMounted(() => {
    // 获取系统信息
    uni.getSystemInfo({
        success: function (res) {
            // 获取屏幕高度
            const screenHeight = res.windowHeight;
            console.log('屏幕高度:', screenHeight);

            // 计算调整后的高度,假设要占用屏幕高度的70%
            const adjustedHeight = screenHeight * 0.7;

            // 使用响应式变量来设置高度
            contextBoxHeight.value = `${adjustedHeight}px`;
        }
    });
});
</script>

<template>
    <view class="contextBox" :style="{ height: contextBoxHeight }">
        <!-- 其他内容 -->
    </view>
</template>

<style scoped>
.contextBox {
    position: relative;
    width: 100%;
    border: 1px solid red;
    overflow-x: hidden;
    overflow-y: hidden;
}
</style>

说明:

  • uni.getSystemInfo: 用于获取设备的系统信息,包括屏幕高度。
  • screenHeight * 0.7 : 计算出contextBox应该占用的高度比例(这里假设为70%)。
  • contextBoxHeight.value = ${adjustedHeight}px`` : 使用响应式变量来动态设置contextBox的高度。

这种方法确保contextBox的高度是相对于整个屏幕的高度,并且在不同设备上都能保持一致的比例。

获取元素高度

在uni-app中,要获取一个元素的高度,可以使用uni.createSelectorQuery。这个API允许你在App、小程序和H5中获取元素的布局信息。以下是一个示例,展示如何获取元素的高度:

vue 复制代码
<template>
    <view class="contextBox">
        <!-- 其他内容 -->
    </view>
</template>

<script setup>
import { ref, onMounted } from 'vue';

// 定义一个响应式变量来存储元素的高度
const elementHeight = ref(0);

onMounted(() => {
    // 创建选择器查询实例
    const query = uni.createSelectorQuery().in(this);

    // 选择要获取高度的元素
    query.select('.contextBox').boundingClientRect(data => {
        if (data) {
            elementHeight.value = data.height;
            console.log('元素高度:', elementHeight.value);
        }
    }).exec();
});
</script>

<style scoped>
.contextBox {
    position: relative;
    width: 100%;
    border: 1px solid red;
    overflow-x: hidden;
    overflow-y: hidden;
}
</style>

说明:

  • uni.createSelectorQuery().in(this): 创建一个选择器查询实例,并指定在当前组件实例中进行查询。
  • .select('.contextBox') : 选择要查询的元素,.contextBox是元素的类名。
  • .boundingClientRect(): 获取元素的布局位置信息,包括高度。
  • .exec(): 执行查询。

这种方法在uni-app中是兼容的,适用于H5、小程序和App等多端环境。确保在onMounted中使用,以便在DOM加载完成后进行查询。

相关推荐
counterxing1 小时前
我整理了一个免费开发资源目录,还做成了 CLI 和 MCP
前端·agent·ai编程
子兮曰7 小时前
Bun v1.3.14 深度解析:Image API、HTTP/3、全局虚拟存储与五十项变革
前端·后端·bun
kyriewen8 小时前
今天,百年巨头一次砍了9200人,而一个离职科学家的实话让全网睡不着觉
前端·openai·ai编程
问心无愧05139 小时前
ctf show web 入门42
android·前端·android studio
kyriewen9 小时前
老板逼我上AI,我偷偷在浏览器里跑LLaMA,省下20万API费
前端·react.js·llm
Beginner x_u9 小时前
前端八股整理(手写 02)|数组转树、数组扁平化、随机打乱一个数组
前端·数组·数组转树·数组扁平化
KaMeidebaby9 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
天若有情67310 小时前
前端高阶性能优化:跳出传统懒加载与预加载,基于用户行为做轻量预判加载
前端·性能优化
小小小小宇10 小时前
前端转后端:SQL 是什么
前端
张元清11 小时前
React Observer Hooks:7 种监听 DOM 而不写样板代码的方式
前端·javascript·面试