Wbudowane tagi <style> a wbudowane właściwości CSS

81

Jaka jest preferowana metoda ustawiania właściwości CSS?

Właściwości stylu wbudowanego:

<div style="width:20px;height:20px;background-color:#ffcc00;"></div>

Właściwości stylu w <style>...</style>znacznikach:

<style>.gold{width:20px;height:20px;background-color:#ffcc00;}</style><div class="gold"></div>
Paweł
źródło
5
Kolejną zaletą tagu stylu, tym bardziej w przypadku zewnętrznego arkusza stylów, jest możliwość ponownego użycia. Teraz, gdy jest to klasa, możesz zastosować ją do więcej niż jednego elementu!
TheZ

Odpowiedzi:

94

Zasady stylu można dołączyć za pomocą:

  • Pliki zewnętrzne
  • Tagi stylu na stronie
  • Atrybut stylu wbudowanego

Generalnie wolę używać połączonych arkuszy stylów, ponieważ:

  • mogą być buforowane przez przeglądarki w celu zwiększenia wydajności; i
  • są o wiele łatwiejsze w utrzymaniu z perspektywy rozwoju.

Jednak Twoje pytanie dotyczy konkretnie styletagu i stylów wbudowanych. styleW tym przypadku wolę używać tagu, ponieważ:

  • zapewnia wyraźne oddzielenie znaczników od stylizacji;
  • tworzy czystsze znaczniki HTML; i
  • jest bardziej wydajne dzięki selektorom do stosowania reguł do wielu elementów na stronie, usprawniając zarządzanie, a także zmniejszając rozmiar strony.

Elementy wbudowane wpływają tylko na ich odpowiedni element.

Istotną różnicą między styletagiem a atrybutem inline jest specyficzność. Specyfika określa, kiedy jeden styl zastępuje inny. Ogólnie style wbudowane mają większą specyficzność.

Przeczytaj CSS: Specyficzne wojny, aby w zabawny sposób spojrzeć na ten temat.

Mam nadzieję że to pomogło!

jmbertucci
źródło
1
Ta kwestia o niemożności kaskadowania stylu w linii sprawiła, że ​​pomyślałem, czy to nie jest technicznie kaskadowe? <div style="border:1px solid #707070; border-left:0">
TheZ
@TheZ Rzeczywiście, może to być kiepskie użycie przeze mnie terminu „kaskada”. Zawsze uważałem, że jedna reguła przechodzi w drugą, zwykle z innych elementów. Zasadniczo dziedziczenie. Będę musiał ponownie przeczytać definicję, aby upewnić się, że prawidłowo używam terminu. W mojej odpowiedzi mam na myśli to, że style inline wpływają tylko na element, w którym są obecne, nic więcej.
jmbertucci
Dodatkową zaletą bloku stylu strony jest to, że upraszcza przenoszenie stylu na zewnętrzną stronę CSS.
Basen
@jmbertucci: Nie zmieniłbym tematu pytania. Jak możesz zastosować reguły takie jak @importlub @font-facez atrybutu stylu? Mówię to również, ponieważ jestem w przypadku, gdy mam atrybut html, style=""ale nie <style></style>tag.
user2284570
Jako dodatek (ponieważ właśnie znalazłem to w wyszukiwarce Google) - w HTML5 jest teraz scopedatrybut (choć nie jest jeszcze szeroko obsługiwany), który pozwala na użycie <style> ... </style>bloków w tekście - np. Developer.mozilla.org/en-US/docs/ Sieć / HTML / Element / style
CD001
20

Oto jeden aspekt, który może rządzić różnicą:

Jeśli zmienisz styl elementu w JavaScript, wpłyniesz na styl wbudowany. Jeśli istnieje już styl, nadpisujesz go na stałe. Ale jeśli styl został zdefiniowany w zewnętrznym arkuszu lub w <style>znaczniku, ustawienie wbudowanego ""stylu przywraca styl z tego źródła.

Niet the Dark Absol
źródło
10

To zależy.

Najważniejsze jest unikanie powtarzania kodu.

Jeśli ten sam kod ma być użyty ponownie 2 lub więcej razy i powinien być zsynchronizowany przy zmianie, użyj zewnętrznego arkusza stylów.

Jeśli użyjesz go tylko raz, myślę, że inline jest w porządku.

Lawrence Mok
źródło
8

Odpowiadając na twoje bezpośrednie pytanie: żadna z tych metod nie jest preferowaną. Użyj osobnego pliku.

Style wbudowane powinny być używane tylko w ostateczności lub ustawiane przez kod JavaScript. Style wbudowane mają najwyższy poziom szczegółowości, więc nadpisuj swoje rzeczywiste arkusze stylów. Może to utrudniać ich kontrolowanie ( !importantz tego samego powodu należy również unikać ).

Osadzony <style>blok nie jest zalecany, ponieważ tracisz zdolność przeglądarki do buforowania arkusza stylów na wielu stronach w Twojej witrynie.

Krótko mówiąc, jeśli to możliwe, powinieneś umieścić swoje style w osobnym pliku CSS.

Spudley
źródło
4

Z punktu widzenia konserwacji, zarządzanie jednym elementem w jednym pliku jest znacznie prostsze niż zarządzanie wieloma elementami w prawdopodobnie wielu plikach.

Oddzielenie stylizacji pomoże ci znacznie ułatwić życie, zwłaszcza gdy obowiązki zawodowe są rozdzielane między różne osoby. Wielokrotne użycie i przenośność pozwolą Ci zaoszczędzić mnóstwo czasu w drodze.

W przypadku używania stylu wbudowanego nadpisuje on wszelkie ustawione właściwości zewnętrzne.

RobB
źródło
3

Zgadzam się z poglądem większości, że preferowaną metodą są zewnętrzne arkusze stylów.

Jednak oto kilka praktycznych wyjątków:

  • Dynamiczne obrazy tła. Arkusze stylów CSS są plikami statycznymi, więc musisz użyć stylu wbudowanego, aby dodać styl dynamiczny (z bazy danych, CMS itp.) background-image.

  • Jeśli element musi być ukryty podczas ładowania strony, użycie do tego zewnętrznego arkusza stylów nie jest praktyczne, ponieważ zawsze będzie pewne opóźnienie, zanim arkusz stylów zostanie przetworzony, a element będzie widoczny, dopóki to się nie stanie. style="display: none;"to najlepszy sposób, aby to osiągnąć.

  • Jeśli aplikacja ma dać użytkownikowi dokładną kontrolę nad określoną wartością CSS, np. Kolorem tekstu, może być konieczne dodanie tego do styleelementów wbudowanych lub <style></style>bloków na stronie . Np. style="color:#{{ page.color }}"Lub<style> p.themed { color: #{{ page.color }}; }</style>

Henz
źródło
0

O ile jest to możliwe, lepiej jest używać klasy .myclass{}i identyfikatora #myclass{}, więc używaj dedykowanego pliku css lub tagu <style></style>w html . Styl wbudowany dobrze jest zmieniać opcję css dynamicznie za pomocą javascript.

Federico
źródło
0

Istnieją różne powody, dla których warto wybrać jeden sposób.

  • Jeśli potrzebujesz określić css do elementów, które są generowane programowo (na przykład modyfikując css dla obrazów o różnych rozmiarach), łatwiejsze może być użycie wbudowanego css.
  • Jeśli jakiś plik CSS jest ważny tylko dla bieżącej strony, powinieneś raczej użyć tagu script niż osobnego pliku .css. Dobrze, jeśli przeglądarka nie musi wykonywać zbyt wielu żądań http.

W przeciwnym razie, jak wspomniano, lepiej jest użyć osobnego pliku css.

Robin Manoli
źródło
0

Możesz ustawić CSS na trzy różne sposoby, jak wspomniano poniżej: -

1.External style sheet
2.Internal style sheet
3.Inline style

Preferowanym / idealnym sposobem ustawiania stylu CSS jest używanie jako zewnętrznych arkuszy stylów, gdy styl jest stosowany na wielu stronach. Korzystając z zewnętrznego arkusza stylów, możesz zmienić wygląd całej witryny sieci Web, zmieniając jeden plik.

przykładowe użycie może być: -

<head>
    <link rel="stylesheet" type="text/css" href="your_css_file_name.css">
</head>

Jeśli chcesz zastosować unikalny styl do pojedynczego dokumentu, możesz użyć wewnętrznego arkusza stylów.

Nie używaj wbudowanego arkusza stylów, ponieważ miesza zawartość z prezentacją i traci wiele zalet.

Sukane
źródło