uniapp中使用自适应
时间: 2023-07-30 09:09:04 浏览: 510
在UniApp中使用自适应布局可以通过使用flex布局和rem单位来实现。
首先,在index.html文件中添加以下代码:
```html
<script>
// 计算rem
function setRemUnit() {
let docEl = document.documentElement
let rem = docEl.clientWidth / 10
docEl.style.fontSize = rem + 'px'
}
setRemUnit()
window.addEventListener('resize', setRemUnit)
</script>
```
这段代码的作用是计算页面宽度并设置根元素的字体大小,以rem作为单位,其中1rem等于根元素的字体大小。这样,在页面中使用rem作为单位时,它们的大小会随着页面宽度的变化而自适应地改变。
接下来,在App.vue中的style标签中使用flex布局,例如:
```css
<style>
html,
body {
height: 100%;
width: 100%;
margin: 0;
padding: 0;
font-size: 16px;
}
#app {
display: flex;
flex-direction: column;
height: 100%;
background-color: #f2f2f2;
}
.header {
flex: none;
height: 48px;
background-color: #fff;
}
.content {
flex: 1;
display: flex;
flex-direction: column;
background-color: #f2f2f2;
}
.item {
flex: none;
height: 48px;
line-height: 48px;
background-color: #fff;
border-bottom: 1px solid #ccc;
}
.item-title {
flex: 1;
padding-left: 10px;
font-size: 16px;
}
.item-arrow {
flex: none;
width: 20px;
height: 20px;
margin-right: 10px;
background-image: url('~@/assets/icons/arrow-right.png');
background-size: cover;
}
</style>
```
这里使用了flex布局来实现页面的自适应,其中#app元素使用flex-direction: column设置为纵向布局,子元素.header和.content使用flex属性分别占据父元素的固定高度和剩余高度,子元素.item也使用flex属性来占据剩余高度并按照纵向布局排列。
最后,在页面中使用rem作为单位来设置元素的大小和间距,例如:
```html
<template>
<div class="content">
<div class="item">
<div class="item-title">Item 1</div>
<div class="item-arrow"></div>
</div>
<div class="item">
<div class="item-title">Item 2</div>
<div class="item-arrow"></div>
</div>
<div class="item">
<div class="item-title">Item 3</div>
<div class="item-arrow"></div>
</div>
</div>
</template>
<style>
.content {
padding: 10px;
}
.item {
margin-bottom: 10px;
}
.item-title {
font-size: 1.6rem;
}
.item-arrow {
width: 2rem;
height: 2rem;
}
</style>
```
在这个例子中,使用rem作为单位来设置.item-title的字体大小和.item-arrow的宽度和高度,它们的大小会根据根元素的字体大小自适应地改变。
阅读全文