Dlaczego moje punktory elementów listy nakładają się na elementy pływające

166

Mam stronę (XHTML Strict), na której umieszczam obraz obok zwykłych akapitów tekstu. Wszystko idzie dobrze, z wyjątkiem sytuacji, gdy zamiast akapitów używana jest lista. Punktory listy nachodzą na pływający obraz.

Zmiana marginesu listy lub elementów listy nie pomaga. Margines jest obliczany od lewej strony, ale pływak wypycha elementów listy na prawo wewnątrz w lisobie. Tak więc margines pomaga tylko wtedy, gdy poszerzę go niż obraz.

Pływak listy obok obrazu również działa, ale nie wiem, kiedy lista znajduje się obok pływaka. Nie chcę przesuwać każdej listy w mojej zawartości, aby to naprawić. Ponadto ruch w lewo powoduje zakłócenie układu, gdy obraz jest przesuwany w prawo zamiast na lewo od listy.

Ustawienie li { list-style-position: inside }przenosi punktory wraz z zawartością, ale powoduje również, że zawijane wiersze zaczynają się w linii z punktorem, a nie w linii powyżej.

Problem jest oczywiście spowodowany wyrenderowaniem pocisku na zewnątrz pudełka, a pływak wypycha zawartość pudełka w prawo (nie samo pudełko). W ten sposób IE i FF radzą sobie z tą sytuacją i o ile wiem, nie źle zgodnie ze specyfikacją. Pytanie brzmi, jak mogę temu zapobiec?

Kamiel Wanrooij
źródło

Odpowiedzi:

280

Znalazłem rozwiązanie tego problemu. Zastosowanie znaku an ul { overflow: hidden; }do ulgwarantuje, że samo pudełko zostanie odepchnięte na bok przez pływak, zamiast zawartości pudełka.

Tylko IE6 potrzebuje ul { zoom: 1; }w naszych komentarzach warunkowych, aby upewnić się, że ulma układ.

Kamiel Wanrooij
źródło
1
+1: Świetny CSS, szukałem jak szalony dobrego, WSZECHSTRONNEGO rozwiązania i oto jest na SO. Jedyną małą wadą jest to, że właściwość zoom nie sprawdza poprawności CSS, ale testowałem i na IE7, IE8 nie jest konieczne, więc prawdopodobnie jest tylko dla IE6.
Marco Demaio
14
Aby to zadziałało musiałem również zastosować: ul, ol {overflow: hidden; padding-left: 40px; margin-left: 0; } ol li, ul li {pozycja-stylu-listy: na zewnątrz; padding-left: 0; } To wymusiło spójne renderowanie we wszystkich przeglądarkach i zmusiło IE6 do wyświetlania punktorów. W przeciwnym razie kule były ukryte. Ul {powiększenie: 1; } było nadal wymagane w ustawieniach specyficznych dla IE6.
Mandrake
1
Tak absurdalnie proste rozwiązanie takiego absurdalnego BŁĘDU w MSIE.
SF.
10
To nie jest idealne rozwiązanie. Jak wspomniał Blazemonger cios, jeśli obraz jest mały, a lista jest bardzo długa, lista nie będzie opływać pływającego obrazu. Lista będzie miała duży margines od góry do końca, jeśli obraz jest bardzo szeroki.
Yang
2
Miły! Nie rozumiem jednak, jak to ma sens, czytając dokument W3C na temat przepełnienia: w3schools.com/cssref/pr_pos_overflow.asp
MSC
66

Dodanie ulepszenia do rozwiązania Glen E. Ivey :

ul {
    list-style: outside disc;
    margin-left: 1em;
}
ul li {
    position: relative;
    left: 1em;
    padding-right: 1em;    
}​

http://jsfiddle.net/mblase75/TJELt/

Wolę tę technikę, ponieważ działa, gdy lista musi opływać pływający obraz, a overflow: hiddentechnika nie. Jednak konieczne jest również dodanie padding-right: 1emdo, liaby zapobiec przepełnieniu pojemnika.

Blazemonger
źródło
Wolę również tę poprawkę, ponieważ pierwsza z nich zepsuła listę rozwijanych plików Twitter Bootstrap i zajęło mi wieczność, aby dowiedzieć się, że powyższa metoda była winowajcą.
Ian Hoar,
2
Dzięki za to. Stosowanie przepełnienia: ukryte; do kontenera. UL uniemożliwił prawidłowe umieszczenie tekstu w poszczególnych pozycjach w bloku pływającym. To rozwiązanie załatwiło sprawę!
jsdalton
1
Napotkałem drobny, ale krytyczny problem z tym rozwiązaniem i chciałbym zasugerować uzupełnienie twojego ulepszenia. Nie wiem dlaczego, ale kiedy dodajesz position: relative;do elementu zamówienia, stwarza to problem ze stosem z zawartością pływającą. Zauważyłem (w Chrome i Firefox), że trudno było najechać kursorem i kliknąć linki w pływającej treści. Rozwiązaniem dla mnie było dodanie position: relative; z-index: 1;elementu pływającego, co wydawało się rozwiązać problem z układaniem.
jsdalton,
7
Niestety w IE 10 pociski zachodzą na pływający element.
Munawwar
1
Podczas gdy ul {overflow: hidden;}rozwiązano ten problem we wszystkich przeglądarkach, powyższe rozwiązanie było jedynym działającym rozwiązaniem tego problemu z Prince XML , konwerterem XHTML + CSS3 na PDF.
Serge Stroobandt
36

Tutaj pojawia się właściwość „display”. Ustaw CSS poniżej, aby lista działała razem z zawartością pływającą.

wyświetlacz: stół; działa z zawartością pływającą (wypełniając lukę), ale bez ukrywania zawartości za nią. Podobnie jak stół :-)

.img {
  float: left;
}

.table {
  display: table;
}
<img class="img" src="https://via.placeholder.com/350x350" alt="">
<ul>
  <li>Test content</li>
  <li>Test content</li>
  <li>Test content</li>
</ul>
<ul class="table">
  <li>Test content</li>
  <li>Test content</li>
  <li>Test content</li>
</ul>

EDYCJA: Pamiętaj, aby dodać klasę, aby wyodrębnić listy, dla których chcesz to zrobić. Np. „Ul.in-content” lub bardziej ogólnie „.content ul”

martinedwards
źródło
29

Wypróbuj list-style-position: inside, aby zmienić układ punktorów.

annakata
źródło
3
list-style-position:insidebyłoby świetnym rozwiązaniem, ale powoduje, że zawijane wiersze zaczynają się w linii z punktorem, a nie w linii powyżej.
Marco Demaio
przepełnienie: ukryte; nie działa dla mojego lewego obrazu pływającego, ale pozycja w stylu listy: wewnątrz to zrobiło! dzięki
menardmam
To było jedyne rozwiązanie, które nadal zawierało zawartość w IE. Dzięki!
jordan314
Jest to świetne rozwiązanie, gdy zawartość przepływa między punktorami a zawartością punktora.
TylersSN
To powinna być wybrana odpowiedź.
Sleek Geek
18

Pod adresem http://archivist.incutio.com/viewlist/css-discuss/106382 znalazłem sugestię, która w moim przypadku zadziałała: nadaj styl elementom „li”:

position: relative;
left: 1em;

Gdzie zamieniasz „1em” na szerokość lewego dopełnienia / marginesu, jaką miałyby elementy listy, gdyby nie było pływaka. Działa to świetnie w mojej aplikacji, nawet obsługując przypadek, w którym dół pływaka występuje na środku list - punktory przesuwają się z powrotem do (lokalnego) lewego marginesu tuż po prawej stronie.

Glen E. Ivey
źródło
2
Fantastyczne rozwiązanie, działa jak urok! Chociaż musiałem brudzić sobie ręce w IE7, ponieważ nie wyświetlał numerów pozycji listy na listach, które nie znajdowały się obok elementu pływającego.
maryisdead
@maryisdead Jakie jest Twoje rozwiązanie dla IE7?
TJ.
IE7 potrzebował dodatkowego marginesu po lewej stronie pozycji listy. Zobacz to skrzypce jsfiddle.net/maryisdead/wu6ew/5 i zwróć uwagę na dwa hacki IE7. Przepraszamy, że nie dodałem tego wcześniej.
maryisdead
18

Dlaczego overflow: hiddendziała

Rozwiązanie jest tak proste, jak:

ul {overflow: hidden;}

Pole bloku z overflow:innym niż visible ustanawia nowy kontekst formatowania bloku dla swojej zawartości. Zalecenie W3C: http://www.w3.org/TR/CSS2/visuren.html#block-formatting

Przykład

Przyciski na mojej stronie , które są <li>zamaskowane, są wykonane w ten sposób. Zmniejsz widoczny obszar (okno) przeglądarki, aby zobaczyć wcięcie w akcji .

Moja witryna jako przykład

Powiązane odpowiedzi

Artykuł z przykładami

Serge Stroobandt
źródło
1
dzięki za wyjaśnienie, dlaczego to działa (nie jest wymienione w przyjętym rozwiązaniu)
schellmax
17

Dodając przynajmniej dla mnie overflow: auto;swoje ulprace.

Aktualizacja

Zaktualizowałem jsfiddle, aby wizualizować, co się dzieje. Mając ulobok pływającego img, zawartość ulbędzie wypychana przez pływak, ale nie przez rzeczywisty pojemnik. Dodając overflow: autocałe ul-box zostanie wypchnięty przez float zamiast tylko zawartości.

Maehler
źródło
13

Możesz przypisać position: relative; left: 10px;do li. (Możesz dodatkowo chcieć nadać mu literę margin-right: 10px;, w przeciwnym razie może stać się zbyt szeroki po prawej stronie).

Lub, jeśli chcesz użyć floatdo ul- jak sugerowali inni - prawdopodobnie możesz zatrzymać resztę przed pływaniem na prawo od ul, używając clear: leftna elemencie następującym po ul.

Chris Lercher
źródło
dzięki Chris, ta pozycja: krewny zadziałała. Problem, który wyniknąłby z wyczyszczenia elementu po ul, polega na tym, że element usuwałby również lewy pływający element div.
superUntitled
7

Używam tego do rozwiązania tego problemu:

ul {
   display: table;
}
Życie jest krótkie
źródło
7

Zrzeczenie się

Listy obok elementów pływających powodują problemy. Moim zdaniem najlepszym sposobem zapobiegania tego rodzaju pływającym problemom jest unikanie pływających obrazów, które przecinają się z treścią. Pomoże również, gdy będziesz musiał wspierać projektowanie responsywne.

Prosty projekt z wyśrodkowanymi obrazami między akapitami będzie wyglądał bardzo atrakcyjnie i będzie o wiele łatwiejszy w obsłudze niż próba uzyskania zbyt fantazyjnego. Jest też o krok od a <figure>.

Ale naprawdę chcę pływających obrazów!

Ok, więc jeśli jesteś szalona uporczywy wystarczająco, aby kontynuować tę ścieżkę, istnieje kilka technik, które mogą być użyte.

Najprościej jest użyć listy overflow: hiddenlub overflow: scrolltak, aby lista była zasadniczo zawinięta, co powoduje cofnięcie wypełnienia do miejsca, w którym jest przydatne:

img {
  float: left;
}
.wrapping-list {
  overflow: hidden;
  padding-left: 40px;
}
<img src="http://placehold.it/100x100"/>
<ul class="wrapping-list">
  <li>lorem</li>
  <li>ipsum</li>
  <li>dolor</li>
  <li>sit</li>
  <li>amet</li>
</ul>

Ta technika ma jednak kilka problemów. Jeśli lista stanie się długa, w rzeczywistości nie zawija się wokół obrazu, co w zasadzie podważa cały cel użycia floatna obrazie.

img {
  float: left;
}
.wrapping-list {
  overflow: hidden;
  padding-left: 40px;
}
<img src="http://placehold.it/100x100"/>
<ul class="wrapping-list">
  <li>lorem</li>
  <li>ipsum</li>
  <li>dolor</li>
  <li>sit</li>
  <li>amet</li>
  <li>lorem</li>
  <li>ipsum</li>
  <li>dolor</li>
  <li>sit</li>
  <li>amet</li>
  <li>lorem</li>
  <li>ipsum</li>
  <li>dolor</li>
  <li>sit</li>
  <li>amet</li>
</ul>

Ale naprawdę chcę zawijać listy!

Ok, więc jeśli jesteś jeszcze bardziej szalony, bardziej wytrwały i absolutnie musisz kontynuować tę ścieżkę, istnieje inna technika, której można użyć do zawijania elementów listy i utrzymywania pocisków.

Zamiast wypełniać <ul>i próbować sprawić, by zachowywał się ładnie z pociskami (czego nigdy nie chce robić), wyjmij te kule <ul>i daj je <li>s. Kule są niebezpieczne, a po <ul>prostu nie są wystarczająco odpowiedzialne, aby właściwie się z nimi obchodzić.

img {
  float: left;
}
.wrapping-list {
  padding: 0;
  list-style-position: inside;
}
.wrapping-list li {
  overflow: hidden;
  padding-left: 25px;
}
<img src="http://placehold.it/100x100"/>
<ul class="wrapping-list">
  <li>lorem</li>
  <li>ipsum</li>
  <li>dolor</li>
  <li>sit</li>
  <li>amet</li>
  <li>lorem</li>
  <li>ipsum</li>
  <li>dolor</li>
  <li>sit</li>
  <li>amet</li>
  <li>lorem</li>
  <li>ipsum</li>
  <li>dolor</li>
  <li>sit</li>
  <li>amet</li>
</ul>

To zachowanie zawijania może robić dziwne rzeczy w złożonej zawartości, więc nie polecam dodawania go domyślnie. O wiele łatwiej jest ustawić go jako coś, na co można się zdecydować, niż coś, co należy zastąpić.

zzzzBov
źródło
Podoba mi się druga opcja, ale tekst w rzeczywistości zaczyna się od kropek w dłuższych tekstach (2 wiersze) :-(
Arany
4

Spróbuj wykonać następujące czynności na swoim znaczniku UL. Powinno to zająć się kulami nakładającymi się na twój obraz i nie musisz zepsuć lewego wyrównania spowodowanego przez list-position: inside.

overflow: hidden; 
padding-left: 2em; 
Joe
źródło
Musiałem użyć tego z rozwiązaniem Blazemongera (punkt 2 powyżej). Sam BLazemonger nie działał w IE 9-11 i Opera. Dzięki temu działa we wszystkich przeglądarkach. Rozwiązanie Kamiela (nr 1) nie zadziałało, ponieważ ukryło moje kule. Być może konflikt z Bootstrap3.
Leraa
3

Sam się z tym zmagałem. Najlepsze, jakie udało mi się osiągnąć, to:

ul {
    list-style-position: inside;
    padding-left: 1em;
    text-indent: -1em;
}

W rzeczywistości tekst nie jest wcięty, ale widać punktor.

Stephen
źródło
2

Zmieniono w celu aktualizacji na podstawie komentarza OP

ok, a następnie podziel go na 2 zagnieżdżone razem elementy div

ul  {background: blue; position:static;}
.therest {position:relative; width:100%}
.indent {float:left; }

<div class="therest">
<p>
Est tincidunt doming iis nobis nibh. Ullamcorper eorum elit lius me delenit. 
</p>
<hr />
<h3>Lorem</h3>
<div class="indent">
<ul>
<li>list element</li>
<li>list element</li>
<li>list element</li>
</ul> 
<div>
the rest now under the UL
</div>

spróbuj zmienić ul li css na

ul {float: left; tło: niebieskie; }

ANC_Michael
źródło
dzięki, to działa, jednak teraz poniższe akapity unoszą się po prawej stronie.
superUntitled
2

Po walce z tym interesującym problemem w kilku projektach i zbadaniu, dlaczego tak się dzieje, w końcu wierzę, że znalazłem zarówno działające, jak i „responsywne” rozwiązanie.

Oto magiczna sztuczka, przykład na żywo: http://jsfiddle.net/superKalo/phabbtnx/

ul {
    list-style: none;
    position: relative;
    padding-left: 0; /* remove any left padding */
    margin-left: 0; /* remove any left margin */
    left: 35px;
}
li {
    padding-left: 0; /* remove any left padding */
    margin-left: 0; /* remove any left margin */
    text-indent: -19px; /* adjust as much as needed */
}
li:before {
    content: '•\00a0\00a0\00a0';
    color: #000; /* bonus: you can customize the bullet color */
}
Kaloyan Kosev
źródło
Dodałem display: flex;do li, aby punktor był wyśrodkowany w pionie, kiedy zmieniam rozmiar czcionki :beforeczęści.
Arany
1

Pracując w systemie LMS bez dostępu do głównego dokumentu, łatwiej było margin-right: 20pxzastosować styl wbudowany dla obrazu. Co zawdzięczam tej stronie .

Lynda Williams
źródło
0

Spróbuj tego:

li{
    margin-left:5px;
}

Jeśli chcesz, żeby poszły w lewo, po prostu wpisz wartość - ## px.

Douglas
źródło
0

lub możesz to zrobić:

 #content ul {
        background:none repeat scroll 0 0 #AACCDD;
        float:left;
        margin-right:10px;
        padding:10px;

a następnie usuń całą stylizację z li

Reece
źródło
1
przesunięcie ul rzeczywiście rozwiązuje problem, jednak pojawia się inny problem ... wszystkie elementy akapitu, które pojawiają się po ul, są przenoszone na prawo od ul.
superUntitled
dałem Ci za to +1 ... Przyjąłem tutaj założenie, patrząc na link powiązany z tym pytaniem, że <p> będzie pływał na prawo od <ul>. Dobry chwyt.
Reece
0

Co powiesz na to?

ul{float:left; clear:right}
Adam Lynch
źródło
0
width: 300px;
height: 30px;
margin-left: auto;
right: 10px;

margin-left: auto spowoduje wyrównanie elementu do prawej strony. Ustaw wysokość i szerokość żądanego elementu - w moim przypadku jest to obraz tła w div wewnątrz

Nikolay Ivanov
źródło
0

Możesz również spróbować przesunąć kursor w ullewo i zdefiniować odpowiedni widthdla niego, tak aby unosił się obok obrazu.

Coś takiego jak ten jsfiddle ?

Houdmont
źródło
0

Naprawiłem to z

div.class-name ul {
  clear: both;
}
Neal Garrett
źródło
0
width: auto; overflow: hidden;
evan toder
źródło
-1

Dodaj display:table; do ul:

ul{display:table;}
evan toder
źródło