两列等高布局在项目中的应用

本文介绍了在Vue项目中遇到的两列等高布局和文本溢出问题,分析了多种解决方案,包括flex布局、margin和padding正负抵消、table布局等。针对垂直方向两端对齐布局,推荐使用绝对定位,而对于多行文本溢出,建议使用CSS方法。最终,选择了使用Flex布局结合绝对定位和CSS多行文本溢出的方法来解决问题。
摘要由CSDN通过智能技术生成

遇到的问题

最近开发一个小型项目,项目只有两个页面,一个主页面,一个列表页面。项目使用的是vue技术栈,在开发页面的组件是遇到了一个布局问题,布局如下:
在这里插入图片描述
要求:
1.外部容器的高度由图片决定
2.图片的宽度固定,右侧元素分配剩余空间
3.右侧元素的高度于图片的一样高
4.右侧上方文字不固定,但是最多不超过两行,下方文字总是位居底部

分析问题

由上面的要求可以得出以下结论:
1.这是一个两列等高布局
2.右侧是一个垂直方向的两端对齐布局
3.需要多行文本溢出

我们看一下这些问题的常见解决方案:

常见的两列等高布局解决方法
1.flex布局

<div class="demo1 demo">
    <div class="left">left</div>
    <div class="right">right</div>
</div>
.demo {
    background-color: aliceblue;
}

.demo .left {
    width: 100px;
    height: 100px;
    background-color: aquamarine;
}

.demo .right {
    background-color: chartreuse;
}

.demo1 {
    display: flex;
    align-items: stretch;
}

.demo1 .right {
    flex: 1;
}

.demo1 .left {
    flex-shrink: 0; /*固定宽度*/
}

缺点: IE9及IE9以下版本不支持flex属性
优点:实现方便,还可以方便实现各种比例

2.使用margin和padding正负抵消

<div class="demo2 demo">
    <div class="left">left</div>
    <div class="right">right</div>
</div>
.demo {
    background-color: aliceblue;
}

.demo .left {
    width: 100px;
    height: 100px;
    background-color: aquamarine;
}

.demo .right {
    background-color: chartreuse;
}

.demo2 {
    overflow: hidden;
}

.demo2 .left,
.demo2 .right {
    float: left;
    margin-bottom: -9999px;
    padding-bottom: 9999px;
}

.demo2 .right {
    float: right;
    width: calc(100% - 100px);
}

优点:兼容所有浏览器
3.table布局

<div class="demo3 demo">
    <div class="left">left</div>
    <div class="right">right<br/>right</div>
</div>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值