2010-10-26 11 views
5

Czy istnieje sposób, aby szerokość <fieldset> była szerokość największego pola w środku?Ustawia szerokość `<fieldset>` na szerokość największego elementu zawierającego

+0

Jedynym sposobem, jaki mogę zastosować w różnych przeglądarkach, jest to, że zachowuje się jak stół, ale nie jest to idealne rozwiązanie dla "zestawu pól". Interesuje Cię, co się pojawi –

+0

Czy możesz nam powiedzieć, czy poniższe rozwiązania są satysfakcjonujące? –

Odpowiedz

3

Czy oznacza to: jsFiddle fieldset that is wide as biggest containing input-element

<form action="#" id="test" name="test"> 
    <fieldset> 
     <input type="text" class="first" /> 
     <input type="text" class="second" /> 
     <input type="text" class="third" /> 

    </fieldset> 

</form> 

fieldset{ 
    overflow: hidden; 
    float: left; 
    background-color: #eee; 
} 
input { 
    display: block; 
} 
input.first{ width: 150px; } 
input.second{ width: 200px; } 
input.third { width: 250px; } 

Jest to pływający fieldset. Jeśli chcesz go w inny sposób, daj nam znać.

+0

Działa nawet w IE6. Miły. –

+0

@Pekka Jak zawsze: spraw, by magia przepełnienia: ukryta; załatw sobie sprawę :) –

4

Po prostu wpisz swoje pytanie w ogólnym kontekście. A <fieldset> jest elementem blokowym, dlatego jego domyślnym zachowaniem jest rozszerzanie w celu wypełnienia dostępnej przestrzeni poziomej. Zasadniczo masz dwie opcje:

  1. Ustaw nową szerokość jawną.
  2. Zmień jego układ z block na coś innego.

Oto krótki przykład:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> 
<html> 
<head><title></title> 
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> 
<style type="text/css"><!-- 
fieldset.explicit-width{ 
    width: 1%; /* Will expand to fit content */ 
} 
fieldset.inline-block{ 
    display: inline-block; 
} 
--></style> 
</head> 
<body> 

<fieldset><legend>Unstyled</legend> 
    <p><input type="text" size="2"></p> 
    <p><input type="text" size="20"></p> 
    <p><input type="text" size="50"></p> 
    <p><input type="text" size="30"></p> 
</fieldset> 

<fieldset class="explicit-width"><legend>Explicit width</legend> 
    <p><input type="text" size="2"></p> 
    <p><input type="text" size="20"></p> 
    <p><input type="text" size="50"></p> 
    <p><input type="text" size="30"></p> 
</fieldset> 

<fieldset class="inline-block"><legend>Inline-block</legend> 
    <p><input type="text" size="2"></p> 
    <p><input type="text" size="20"></p> 
    <p><input type="text" size="50"></p> 
    <p><input type="text" size="30"></p> 
</fieldset> 

</body> 
</html> 

Aktualizacja: Zapomniałam wspomnieć, że pływający element poziomie bloku również zmienia swój układ.

Powiązane problemy