CSS text-wrap: saldo

Klasyczna technika typograficzna polegająca na ręcznym umieszczaniu znaków końca wiersza w celu wyrównania bloków tekstu została wprowadzona do CSS.

Adam Argyle
Adam Argyle

Wartość balance w polu text-wrap jest częścią tekstu CSS poziomu 4. Aby dowiedzieć się, jak jeden wiersz kodu CSS może znacznie poprawić układ tekstu, zapoznaj się z przykładami w tym poście.

Obsługa przeglądarek

  • Chrome: 114.
  • Edge: 114.
  • Firefox: 121.
  • Safari: 17.5.

Źródło

Wypróbuj wersję demonstracyjną

Bez text-wrap: balance projektanci, edytujący treści i wydawcy mają niewiele narzędzi do zmiany równowagi między liniami. Najlepsze opcje to użycie <wbr> lub &shy;, aby ułatwić układanie tekstu i podejmowanie trafniejszych decyzji dotyczących przełamania wiersza i słów.

Jako programista nie znasz ostatecznego rozmiaru, rozmiaru czcionki ani nawet języka nagłówka lub akapitu. Wszystkie zmienne potrzebne do efektywnego i estetycznego łamania tekstu znajdują się w przeglądarce. Dlatego widzimy nagłówek z opakowaniem, jak na tym obrazku:

Nagłówek jest wyróżniony za pomocą Narzędzi deweloperskich, rozciąga się na pełną szerokość obszaru wewnętrznego, a w drugim wierszu znajduje się 2 wiszące słowa.
Wypróbuj wersję demonstracyjną
.unbalanced {
  max-inline-size: 50ch;
}

Dzięki text-wrap: balance z CSS Text 4 możesz poprosić przeglądarkę o znalezienie najlepszego rozwiązania do wyrównywania tekstu do linii. Przeglądarka zna wszystkie te czynniki, takie jak rozmiar czcionki, język i przydzielone miejsce. Dzisiaj wyniki zrównoważenia łamań wiersza w przeglądarce wyglądają tak:

Nagłówek jest wyróżniony tak jak w poprzedniej wersji narzędzi deweloperskich, ale tym razem nie zajmuje całej szerokości. Rozpoczął się na nowej linii przed końcem, więc jest to wyrównany blok tekstu.
Wypróbuj demo
.balanced {
  max-inline-size: 50ch;
  text-wrap: balance;
}

Dobrze jest je zobaczyć obok siebie, bez nakładania się informacji debugujących.

Dwa poprzednie przykłady są pokazane razem – jeden jest oznaczony jako niezrównoważony, a drugi jako niezrównoważony.

Wyrównany blok tekstu powinien być bardziej przyjemny dla oka. Przyciąga uwagę i jest ogólnie łatwiejszy do odczytania.

Jak znaleźć równowagę

Nagłówki to pierwsza rzecz, którą widzą czytelnicy. Powinny być atrakcyjne wizualnie i łatwe do przeczytania. Przyciąga uwagę użytkowników i buduje poczucie jakości. Dobra typografia budzi zaufanie czytelników i zachęca ich do dalszego czytania.

Tradycyjnie trzeba było robić to ręcznie lub optycznie, ponieważ projektant równoważący tekst nie chce odpowiadać na oko, a nie algorytm matematyczny. Ten temat jest często określany jako dopasowanie metryczne i optyczne. W przypadku dużych publikacji, takich jak New York Times, zrównoważenie nagłówków jest bardzo ważnym szczegółem wrażenia użytkownika.

Wypróbuj wersję demonstracyjną

Równoważenie tekstu w typografii sięga początków drukarstwa, gdy drukarze ręcznie umieszczali litery. Wraz z rozwojem narzędzi i technik zmieniały się też wyniki. Obecnie projektanci mają różne kolory, wagę, rozmiar i inne elementy, aby zrównoważyć tekst w swoich projektach.

W internecie kontrola jest jednak mniejsza, ponieważ dokument zmienia rozmiar i kolor w zależności od użytkowników. text-wrap: balance wprowadza sztukę równoważenia tekstu w internecie w sposób zautomatyzowany, bazując na pracy i tradycjach projektantów z branży poligraficznej.

Zrównoważone nagłówki

To będzie i powinno być główne zastosowanie środowiska text-wrap: balance. Narysuj oko o odpowiednim rozmiarze, symetryczne i czytelne. Ustaw wszystkie nagłówki na zrównoważony tekst za pomocą tego kodu CSS:

h1,h2,h3,h4,h5,h6 {
  text-wrap: balance;
}

Samo zastosowanie tego stylu może nie przynieść oczekiwanych rezultatów, ponieważ tekst musi się łamać, a dlatego musi mieć określoną maksymalną długość wiersza. W przykładach w tym poście zobaczysz styl max-inline-size. Jest on podobny do stylu max-width, ale można go ustawić raz dla dowolnego języka.

Ograniczenia

Dostosowanie tekstu do obrazu nie jest bezpłatne. Przeglądarka musi wykonać kilka iteracji, aby znaleźć najlepsze rozwiązanie do spakowania. Ten koszt wydajności jest ograniczany przez regułę, która działa tylko w przypadku 6 zawiniętych linii lub mniej.

Wypróbuj wersję demonstracyjną

Możliwe spowolnienie działania witryny

Nie zalecamy stosowania wyrównania tekstu do całego projektu. Jest to niepotrzebne żądanie ze względu na limit 6 wierszy i może mieć wpływ na szybkość renderowania strony.

Nie
* {
  text-wrap: balance;
}
ROZWAŻ ZMIANĘ
h1, h2, h3, h4, h5, h6, blockquote {
  text-wrap: balance;
}

Dużą zaletą tej funkcji jest to, że nie musisz czekać i dobierać czasu przełamania tekstu do czasu ładowania czcionek, jak to ma miejsce w przypadku JavaScriptu. O to zadba przeglądarka.

Interakcje z usługą white-space

Tekst z balansem konkuruje z usługą white-space, ponieważ jeden z nich wymaga braku opakowania, a drugi – zrównoważenia. Aby rozwiązać ten problem, odznacz właściwość biała przestrzeń, a następnie ponownie zastosuj wyważony układ.

.balanced {
  white-space: unset;
  text-wrap: balance;
}

Wyrównywanie nie zmieni rozmiaru wbudowanego elementu.

Niektóre rozwiązania JavaScriptu mają tę zaletę, że umożliwiają zrównoważony tekst, ponieważ zmieniają max-width samego elementu zawierającego. Dodatkową zaletą jest to, że jest ona „zapakowana” w blok zrównoważonym. text-wrap: balance nie ma takiego efektu i można to zobaczyć w tym przykładzie:

Nagłówek jest wyróżniony tak jak w poprzednich Narzędziach deweloperskich, ale tym razem nie rozciąga się na pełną szerokość. Rozpoczyna się na nowej linii przed końcem i jest to wyrównany blok tekstu.

Widzisz, że szerokość wyświetlana w Narzędziach deweloperskich ma na końcu dużo dodatkowego miejsca? Dzieje się tak, ponieważ jest to tylko styl zawinięcia, a nie styl zmiany rozmiaru. Dlatego jest kilka sytuacji, w których text-wrap: balance nie jest zbyt dobry (przynajmniej moim zdaniem). Na przykład nagłówki na karcie (lub w dowolnym kontenerze z ramkami lub cieniami).

Zrównoważony tekst powoduje nierównowagę w zawartym elemencie.

krótki opis techniki używanej przez przeglądarkę;

Przeglądarka przeprowadza wyszukiwanie binarne w celu znalezienia najmniejszej szerokości, która nie spowoduje żadnych dodatkowych wierszy, zatrzymując się na 1 pikselu CSS (a nie pikselu wyświetlacza). Aby jeszcze bardziej zminimalizować liczbę kroków w wyszukiwaniu binarnym, przeglądarka zaczyna od 80% średniej szerokości linii.