11

在我的网络应用程序中,我有一个工具栏,它是一个 div:

div 有 3 个跨度。3 个 span 的内容稍后会被填充。

并且各个跨度的大小每次都不同。

<div>
    <span id="ab1" style="display: inline-block;"></span>
    <span id="ab2" style="display: inline-block;"></span>
    <span id="ab3" style="display: inline-block;"></span>
</div>

现在,我想,跨度“ab1”应该放在左边,“ab2”和“ab3”放在div的右边。

这可能没有向右/向左浮动吗?

4

3 回答 3

11

使用position:absolutetext-align:right

CSS

div{background:red; text-align:right; position:relative;}
#ab1{position:absolute; left:0; background:yellow;}
#ab2{background:yellow;}
#ab3{background:yellow;}

演示

于 2013-02-06T09:54:45.003 回答
9

您可以display flex用于容器和margin-left: auto#ab2。

div{
    display: flex;
}
#ab2{
    margin-left: auto;
}
于 2018-06-10T10:23:32.627 回答
5

使用和flex添加元素orderspan

div {
    display: flex;
    flex-grow: 1;
    justify-content: space-between;   /* space-between / space-around  */
}

/* order the elements as you like ..  */
#ab1 {
    order: 0;
}

#ab2 {
    order: 1;
}

#ab3 {
    order: 2;
}


/* incase text in span is large margin may need */
span {
    margin-left: 10px;
}

演示

于 2017-06-18T06:07:06.063 回答