[英]Align baseline of text to the top of another element (CSS)
我確定之前有人這樣做了,但是我無法想出足夠好的搜索查詢來找到它。
我想將基線(不是文本元素的底部,文本本身的基線)與另一個div的頂部對齊。 這也意味着我希望下降器與它下面的另一個div相交。
HTML看起來像這樣:
<div id="text">text</div>
<div id="box"></div>
所以我想.text
將其基線直接放在.box
的上邊緣.box
,我希望.box
(如“g”)與.box
相交。 我試圖在CSS中使用vertical-align
屬性,但它無法正常工作。 我有一種感覺,這就是我需要的東西。 有任何想法嗎? 謝謝!
看到這個圖像,灰色框是.box
,文本部分是.text
。 注意下降到框中的下降器和基線與盒子完全接觸。
像這樣,使用line-height
?
#box{ display:block; width:100%; height:200px; background-color:#ccc; } #text{ text-align:center; font-size:48px; line-height:30px; }
<div id="text">TEXT<em>pgjiq</em></div> <div id="box"></div>
困難在於字體的高度不是由例如大寫字母T
的高度確定的 - 它還包括上升和下降。
沒有辦法讓CSS認識到上升器和下降器占用的空間量。 逐像素地推動它是你最好的選擇。
如果您擔心這會被保留在不同的屏幕上以及放大和縮小,那么它應該沒問題:瀏覽器非常擅長保留尺寸之間的比例。
也就是說,100%確定的唯一方法是使用圖像或SVG。
嘗試這個:
<!DOCTYPE html>
<html>
<head>
<style>
* {font-family: tahoma; font-size: 14px;}
#text {margin-bottom: -3px;}
#box {background-color: #ddd; width: 100%; height: 100px;}
</style>
</head>
<body>
<div id="text">TEXT gjipq</div>
<div id="box"></div>
</body>
</html>
我能夠完成圖像顯示的方式是在底部框中使用負邊距。
*{
margin: 0;
}
.text{
background: lightgrey;
font-size: 24px;
}
.box{
background-color: tomato;
width: 100%;
height: 40px;
margin-top: -12px;
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.