89

プロパティvertical-alignだけでなくfloat、どのように使用できますか?divを使用vertical-alignしない場合は正常に動作しますfloat。しかし、フロートを使用すると、機能しません。float:right最後のdivにを使用することが重要です。

私は次のことを試みています。すべてのdivからfloatを削除すると、正常に機能します。

<div class="wrap">
    <div class="left">First div, float left,  has more text.</div>
    <div class="left2">Second div, float left </div>
    <div class="right">Third div, float right</div>
</div>

CSS:

.wrap{
    width: 500px;
    overflow:hidden;    
    background: pink;
}

.left {
    width: 150px;       
    margin-right: 10px;
    background: yellow;  
    float:left;
    vertical-align: middle;  
    display:inline-block

}

.left2 {
    width: 150px;    
    margin-right: 10px;
    background: aqua;
    float:left;
    vertical-align: middle;   
    display:inline-block
}

.right{
    width: 150px;
    background: orange;
    float:right;
    vertical-align: middle;
    display:inline-block
}

JSFiddle

4

3 に答える 3

87

行の高さを設定する必要があります。

<div style="border: 1px solid red;">
<span style="font-size: 38px; vertical-align:middle; float:left; line-height: 38px">Hejsan</span>
<span style="font-size: 13px; vertical-align:middle; float:right; line-height: 38px">svejsan</span>
<div style="clear: both;"></div>

http://jsfiddle.net/VBR5J/

于 2013-06-14T07:26:50.927 に答える
13

編集:

vertical-align CSSプロパティは、インライン、インラインブロック、またはテーブルセル要素の垂直方向の配置を指定します。

垂直整列について理解するためにこの記事を読んでください

于 2012-07-30T08:54:47.850 に答える
9

実際、垂直方向の配置は浮動要素では機能しません。これは、フロートが要素をドキュメントの通常のフローから持ち上げるためです。変換、表示:テーブル、絶対位置、行の高さ、js(最後の手段かもしれません)、または単純な古いhtmlテーブル(コンテンツが実際には表形式)。この問題については白熱した議論があることがわかります。

ただし、これが3つのdivを垂直方向に揃える方法です。

.wrap{
    width: 500px;
    overflow:hidden;    
    background: pink;
}

.left {
    width: 150px;       
    margin-right: 10px;
    background: yellow;  
    display:inline-block;
    vertical-align: middle; 
}

.left2 {
    width: 150px;    
    margin-right: 10px;
    background: aqua; 
    display:inline-block;
    vertical-align: middle; 
}

.right{
    width: 150px;
    background: orange;
    display:inline-block;
    vertical-align: middle; 
}

固定幅、表示:インラインブロックとフローティングの両方が必要な理由がわかりません。

于 2015-04-07T09:53:35.787 に答える