微信小程序动态获取和设置元素宽高

需求

由于设计界面时常常会用到vh和rpx来设置元素的宽高,但是由于每个手机屏幕的高都不确定,而有时候在设计界面时想把内容刚好适应屏幕大小。

解决方法

  1. 设置要动态修改宽高的元素。
<view class="top">
	……
</view>
<view :style="{ height: viewHeight + 'px' }">
	……
</view>

export default {
	data() {
		return {
			……
			viewHeight: '',
		};
	}
  1. 先动态获取屏幕的宽高和元素的宽高。
onLoad() {
	_self = this;
	uni.getSystemInfo({
		success: function(res) {
			console.log(res);
			let info = uni.createSelectorQuery().select('.top');(单引号里的是元素的类名,即class)
			info.boundingClientRect(function(data) {
				//res - 屏幕的所以参数
				//data - 该类名所对应的元素的各种参数
				//可以在这里进行加减乘除计算,并将值进行绑定
				_self.viewHeight = (res.windowHeight - data.height) / 3;
			}).exec();
		}
	});
	},

最后,如本文有错误的地方,欢迎指正!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值