Vue父组件和子组件对于width:100%和width:inherit

我想让子组件的宽度等于父组件的宽度。
父组件宽度为一个具体值比如说1000px.我将子组件宽度设为了100%。按道理说应该是可以等于父组件的宽度的,但结果并没有,而是通栏了。然后我又将子组件宽度设为了inherit。结果宽度就是父组件的宽度了。

//父组件
 <div class="app-container">
    <Header></Header>
  </div>
<style lang="less" scoped>
.app-container {
  padding-top: 45px;
  padding-bottom: 50px;
  width: 80%;
  margin: 0 auto;
}
</style>
//子组件
  <div class="header-container">子组件</div>
<style lang="less" scoped>
.header-container {
  height: 45px;
  width: inherit;
  background-color: #1d7bff;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  position: fixed;
  top: 0;
  z-index: 999;
}
</style>

 出现这个问题的原因

原来我忘记了子组件设了绝对定位,但父组件没有设置相对定位。所以子组件脱离了父组件,导致子组件的百分之百直接和body的宽度一致了。而子组件虽然定位上脱离了文档流,但在节点树上他依然是父组件的儿子,所以如果设置width:inherit的时候,浏览器会将父组件的宽度赋值给他。

解决:

就是给子组件的宽度设置成width:inherit  或者给父组件设置position: relative

 

width设置成100%;

 

width设置成inherit

最后 

如果还有什么疑问或者建议,可以多多交流,文笔有限,才疏学浅,文中若有不正之处,万望告知。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值