我有一個(gè)類似的布局:
<div>
<table>
</table>
</div>
我希望div只擴(kuò)展到與我的表一樣寬。
解決方案是將div設(shè)置為display: inline-block。
您想要一個(gè)塊元素,它具有CSS所說(shuō)的收縮到適合的寬度,而規(guī)范并沒(méi)有提供一個(gè)獲得這種東西的好方法。在CSS2中,縮小到合適并不是一個(gè)目標(biāo),而是指處理瀏覽器“不得不”憑空獲得寬度的情況。這些情況是:
漂浮物 絕對(duì)定位元素 內(nèi)嵌塊元素 表格元素 當(dāng)沒(méi)有指定寬度時(shí)。我聽(tīng)說(shuō)他們想在CSS3中加入你想要的東西。現(xiàn)在,湊合著用上面的一個(gè)。
不直接公開(kāi)該特性的決定可能看起來(lái)很奇怪,但是有一個(gè)很好的理由。它是昂貴的。縮小到適合意味著至少格式化兩次:在知道一個(gè)元素的寬度之前,你不能開(kāi)始格式化它,并且你不能在不遍歷整個(gè)內(nèi)容的情況下計(jì)算寬度。另外,人們并不像想象的那樣經(jīng)常需要收縮配合元件。為什么你的桌子周圍需要額外的格子?也許表格標(biāo)題就是你所需要的。
我認(rèn)為使用
display: inline-block;
可以工作,但是我不確定瀏覽器的兼容性。
另一個(gè)解決方案是將您的div包裝在另一個(gè)div中(如果您希望保持塊行為):
HTML:
<div>
<div class="yourdiv">
content
</div>
</div>
CSS:
.yourdiv
{
display: inline;
}
display: inline-block為元素添加額外的邊距。
我推薦這個(gè):
#element {
display: table; /* IE8+ and all other modern browsers */
}
額外收獲:你現(xiàn)在也可以通過(guò)添加margin: 0 auto來(lái)輕松地將這個(gè)新奇的#元素居中。
你可以試試fit-content (CSS3):
div {
width: fit-content;
/* To adjust the height as well */
height: fit-content;
}
瀏覽器支持 規(guī)格 有兩個(gè)更好的解決方案
顯示:內(nèi)嵌-塊;
運(yùn)籌學(xué)
顯示:表格;
在這兩個(gè)顯示器之外:桌子;更好,因?yàn)轱@示:inline-block;添加額外的邊距。
對(duì)于顯示:內(nèi)嵌塊;您可以使用負(fù)邊距方法來(lái)修復(fù)額外的空間
對(duì)我有用的是:
display: table;
在div中。(在火狐和谷歌Chrome上測(cè)試)。
Foo Hack跨瀏覽器支持內(nèi)嵌塊樣式(2007-11-19)。
不知道這將出現(xiàn)在什么樣的上下文中,但我相信CSS樣式的屬性浮動(dòng)無(wú)論是向左還是向右都會(huì)有這種效果。另一方面,它也會(huì)有其他副作用,比如允許文本在它周圍浮動(dòng)。
如果我錯(cuò)了,請(qǐng)糾正我,我不是100%確定,目前也不能自己測(cè)試。
你問(wèn)題的答案在未來(lái),我的朋友...
即& quot內(nèi)在的& quot即將推出最新的CSS3更新
width: intrinsic;
不幸的是IE落后于它,所以它還不支持它
關(guān)于它的更多信息:CSS內(nèi)在& amp外部規(guī)模模塊級(jí)別3,我可以使用嗎?:內(nèi)在& amp外在尺寸。
現(xiàn)在你必須滿足于& ltspan & gt或者& ltdiv & gt干勁十足地開(kāi)始做;毅然開(kāi)始
display: inline-block;
對(duì)我來(lái)說(shuō)很好:)
兼容CSS2的解決方案是使用:
.my-div
{
min-width: 100px;
}
您也可以浮動(dòng)您的div,這將迫使它盡可能小,但如果您的div中有任何內(nèi)容是浮動(dòng)的,您將需要使用clearfix:
.my-div
{
float: left;
}
評(píng)論中提到了這一點(diǎn),但很難在其中一個(gè)答案中找到,所以:
如果您出于任何原因使用display: flex,您可以使用:
div {
display: inline-flex;
}
這也是跨瀏覽器的廣泛支持。
好的,在很多情況下你甚至不需要做任何事情,因?yàn)槟J(rèn)情況下div的高度和寬度是自動(dòng)的,但是如果不是你的情況,應(yīng)用內(nèi)嵌塊顯示會(huì)對(duì)你有用...看看我為您創(chuàng)建的代碼,它能做您所需要的事情:
div {
display: inline-block;
}
<div>
<table>
<tr>
<td>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi ultrices feugiat massa sed laoreet. Maecenas et magna egestas, facilisis purus quis, vestibulum nibh.</td>
<td>Nunc auctor aliquam est ac viverra. Sed enim nisi, feugiat sed accumsan eu, convallis eget felis. Pellentesque consequat eu leo nec pharetra. Aenean interdum enim dapibus diam.</td>
<td>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi ultrices feugiat massa sed laoreet. Maecenas et magna egestas, facilisis purus quis, vestibulum nibh.</td>
</tr>
</table>
</div>
只需設(shè)置寬度和高度,以適應(yīng)內(nèi)容。這很簡(jiǎn)單。
div {
width: fit-content;
height: fit-content;
padding: 10px;
}
我在加padding:10px;。如果忽略它,div元素將完全粘在表格上,看起來(lái)有點(diǎn)笨拙。填充將在元素的邊框和內(nèi)容之間創(chuàng)建給定的空間。但這是你的愿望,不是強(qiáng)制性的。
你可以試試這個(gè)代碼。遵循CSS部分中的代碼。
div {
display: inline-block;
padding: 2vw;
background-color: green;
}
table {
width: 70vw;
background-color: white;
}
<div>
<table border="colapsed">
<tr>
<td>Apple</td>
<td>Banana</td>
<td>Strawberry</td>
</tr>
<tr>
<td>Apple</td>
<td>Banana</td>
<td>Strawberry</td>
</tr>
<tr>
<td>Apple</td>
<td>Banana</td>
<td>Strawberry</td>
</tr>
</table>
</div>
只需在你的CSS文件中加入一個(gè)樣式
div {
width: fit-content;
}
嘗試使用width: max-content屬性根據(jù)內(nèi)容大小調(diào)整div的寬度。
試試這個(gè)例子,
<!DOCTYPE html>
<html>
<head>
<style>
div.ex1 {
width:500px;
margin: auto;
border: 3px solid #73AD21;
}
div.ex2 {
width: max-content;
margin: auto;
border: 3px solid #73AD21;
}
</style>
</head>
<body>
<div class="ex1">This div element has width 500px;</div>
<br>
<div class="ex2">Width by content size</div>
</body>
</html>
只需使用display:inline;(或空白:nowrap).
我希望你覺(jué)得這是有用的。
您可以以@user473598的身份使用inline-block,但是要小心舊的瀏覽器..
/* Your're working with */
display: inline-block;
/* For IE 7 */
zoom: 1;
*display: inline;
/* For Mozilla Firefox < 3.0 */
display:-moz-inline-stack;
Mozilla根本不支持內(nèi)聯(lián)塊,但是他們有-moz-inline-stack,也差不多
一些跨瀏覽器內(nèi)聯(lián)塊顯示屬性: https://CSS-tricks . com/snippet/CSS/cross-browser-inline-block/
您可以在https://robertnyman . com/2010/02/24/CSS-display-inline-block-why-it-rocks-and-why-it-sucks/中看到一些帶有此屬性的測(cè)試
我知道人們有時(shí)不喜歡表格,但我必須告訴你,我嘗試了css內(nèi)聯(lián)方法,它們?cè)谝恍ヾiv中工作,但在其他div中不工作,所以,在表格中包含擴(kuò)展div真的更容易...和...它可以有也可以沒(méi)有inline屬性,但仍然是這個(gè)表來(lái)保存內(nèi)容的總寬度。=)
這里有一個(gè)工作演示-
.floating-box {
display:-moz-inline-stack;
display: inline-block;
width: fit-content;
height: fit-content;
width: 150px;
height: 75px;
margin: 10px;
border: 3px solid #73AD21;
}
<h2>The Way is using inline-block</h2>
Supporting elements are also added in CSS.
<div>
<div class="floating-box">Floating box</div>
<div class="floating-box">Floating box</div>
<div class="floating-box">Floating box</div>
<div class="floating-box">Floating box</div>
<div class="floating-box">Floating box</div>
<div class="floating-box">Floating box</div>
<div class="floating-box">Floating box</div>
<div class="floating-box">Floating box</div>
</div>
我的CSS3 flexbox解決方案有兩種風(fēng)格:頂部的表現(xiàn)像一個(gè)span,底部的表現(xiàn)像一個(gè)div,在包裝器的幫助下占據(jù)所有寬度。它們的類分別是“top”、“bottom”和“bottomwrapper”。
body {
font-family: sans-serif;
}
.top {
display: -webkit-inline-flex;
display: inline-flex;
}
.top, .bottom {
background-color: #3F3;
border: 2px solid #FA6;
}
/* bottomwrapper will take the rest of the width */
.bottomwrapper {
display: -webkit-flex;
display: flex;
}
table {
border-collapse: collapse;
}
table, th, td {
width: 280px;
border: 1px solid #666;
}
th {
background-color: #282;
color: #FFF;
}
td {
color: #444;
}
th, td {
padding: 0 4px 0 4px;
}
Is this
<div class="top">
<table>
<tr>
<th>OS</th>
<th>Version</th>
</tr>
<tr>
<td>OpenBSD</td>
<td>5.7</td>
</tr>
<tr>
<td>Windows</td>
<td>Please upgrade to 10!</td>
</tr>
</table>
</div>
what you are looking for?
<br>
Or may be...
<div class="bottomwrapper">
<div class="bottom">
<table>
<tr>
<th>OS</th>
<th>Version</th>
</tr>
<tr>
<td>OpenBSD</td>
<td>5.7</td>
</tr>
<tr>
<td>Windows</td>
<td>Please upgrade to 10!</td>
</tr>
</table>
</div>
</div>
this is what you are looking for.
通過(guò)篡改Firebug,我找到了屬性值-moz-fit-content,這正是OP想要的,可以如下使用:
width: -moz-fit-content;
雖然它只在Firefox上運(yùn)行,但我找不到任何適用于Chrome等其他瀏覽器的等效軟件。
這將使父div寬度與最大元素寬度相同。
嘗試顯示:inline-block;。為了跨瀏覽器兼容,請(qǐng)使用下面的css代碼。
div {
display: inline-block;
display:-moz-inline-stack;
zoom:1;
*display:inline;
border-style: solid;
border-color: #0000ff;
}
<div>
<table>
<tr>
<td>Column1</td>
<td>Column2</td>
<td>Column3</td>
</tr>
</table>
</div>
div{
width:fit-content;
}
<div>
<table>
</table>
</div>
我已經(jīng)解決了一個(gè)類似的問(wèn)題(我不想使用display: inline-block,因?yàn)轫?xiàng)目是居中的),方法是在div標(biāo)簽中添加一個(gè)span標(biāo)簽,并將CSS格式從外部div標(biāo)簽移動(dòng)到新的內(nèi)部span標(biāo)簽。如果display: inline block不適合你,就把它作為另一個(gè)選擇。
我們可以在div元素上使用兩種方法中的任何一種:
display: table;
或者,
display: inline-block;
我更喜歡用display:table;,因?yàn)樗约禾幚硭蓄~外的空格。而顯示:內(nèi)嵌塊需要一些額外的空間固定。