【Vue】Vue中使一个div铺满全屏

在Vue中实现div全屏铺满的方式与纯CSS实现类似,只是在Vue组件中应用CSS的方式略有不同。

最近在项目开发中,就遇到了这个问题,特此记录一下,方便大伙避坑。

有这么一段代码:

复制代码
<template>
  <div class="fullscreen-div">
    <!-- 内容区域 -->
  </div>
</template>

<script>
export default {
  name: 'MyComponent',
}
</script>

<style scoped>

</style>

在css中常要的三种铺满全屏方式:

  1. 使用vh和vw单位
  2. 使用绝对定位和100%宽高
  3. 使用Flexbox布局

比如我们使用第二种:

复制代码
<style scoped>
.fullscreen-div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
</style>

在这个示例中,我们在Vue组件中定义了一个名为MyComponent的组件,其中包含一个类名为fullscreen-div的div元素。

通过在<style>标签中定义.fullscreen-div的样式,我们使用了绝对定位和百分比宽高的方式,使得该div元素能够全屏铺满浏览器窗口。

刷新下页面,你会发现div的四周还存在一段留白,这是怎么回事?

这可能由于浏览器默认样式或其他元素的样式导致的,为了确保div元素能够完全铺满整个浏览器窗口,可以尝试以下几种方法:

1.重置浏览器默认样式

复制代码
html, body {
  margin: 0;
  padding: 0;
}

2.设置所有的父级的高度为100%

复制代码
html, body, #app {
  height: 100%;
  margin: 0;
  padding: 0;
}

这两个方法,都可以解决留白问题。

用第二种的话,直接就能实现div铺满全屏了。

复制代码
<template>
  <div class="fullscreen-div">
    <!-- 内容区域 -->
  </div>
</template>

<script>
export default {
  name: 'MyComponent',
}
</script>

<style scoped>
html, body, #app {
  height: 100%;
  margin: 0;
  padding: 0;
}

.fullscreen-div{
  height: 100%;
}
</style>

直接这样设置,就能够解决网页四周出现留白的问题,还确保div元素能够完全铺满整个浏览器窗口。

不管做什么,只要坚持下去就会看到不一样!
相关推荐
掘金者阿豪12 小时前
在AI时代,没有人是“只写一行代码的人”——我们为何都在被迫成为全栈?
vue.js·后端
早點睡39012 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-contacts
javascript·react native·react.js
☞无能盖世♛逞何英雄☜12 小时前
Echarts数据可视化应用
前端·信息可视化·echarts
2501_9436103613 小时前
我爱导航系统美化版源码网址导航系统带后台-【全开源】
前端·后端·html·php
__Yvan13 小时前
Kotlin 的 ?.let{} ?: run{} 真的等价于 if-else 吗?
android·开发语言·前端·kotlin
英俊潇洒美少年13 小时前
JS 事件循环(宏/微任务) ↔ Vue ↔ React** 三者的关系
javascript·vue.js·react.js
Greg_Zhong13 小时前
Js中异步编程的知识扩展【异步有哪些、如何执行、宏任务和微任务等】
开发语言·javascript
陈随易13 小时前
我也曾离猝死很近
前端·后端·程序员
烈焰飞鸟13 小时前
iconfont 在 uni-app 项目中的完整使用指南
vue.js·uni-app·iconfont
喵个咪13 小时前
GoWind Content Hub|风行,开箱即用的企业级前后端一体内容中台
前端·后端·cms