Att lägga ut texten och innehållet på en webbplats med HTML-kod är bara en del av byggnaden framsidan av en webbplats. En annan stor del av denna process är att skapa den visuella stilen, som styrs av reglerna för CSS.
När vi bygger en ny webbplats eller gör stora layoutändringar på en befintlig, vill vi oundvikligen att specifika delar av vår webbplats ska se ut på ett visst sätt. För att göra detta är det viktigt att förstå hur man använder de olika CSS-kombinerare, till exempel CSS-efterkommande väljare. Denna CSS-kombinator gör det möjligt för stora delar av en webbplats att få samma stiländringar på en gång.
Vad är en CSS Descendant Selector?
CSS-väljaren är en av fyra olika CSS-kombinerare. När du lägger till ett enda mellanslag () mellan två väljare kommer samma stilelement också att gälla för den andra väljaren, med tanke på att ättlingarna delar samma första väljare.
För att förstå en CSS-efterkommande väljare måste du först förstå CSS-väljare. Det bästa sättet att beskriva en väljare är att det är en CSS-operatör som identifierar den bit HTML som du försöker utforma. Det kallas en väljare eftersom den "väljer" vilken HTML-bit som helst delar samma operatör som CSS-föräldern.
Vanliga exempel på sådana operatörer är:
div
Detta är en tagg som definierar ett avsnitt av HTML, som kan innehålla saker som stycken och innehåll, eller:
li
vilket är en beställd lista. En annan liknande tagg är:
ul
Detta skapar en oordnad lista. Mer komplexa mönster kallas också selektorer. Enkelt uttryckt berättar en CSS ättlingväljare en webbplats hur den ska se ut när en väljare är "kapslad" under en gemensam förfader.
Den första väljaren blir CSS-förälder, eller "förfaderns" väljare, och den andra väljaren blir ättlingen. Tänk på hur en filkatalog fungerar: CSS-föräldern är som en mapp som innehåller andra mappar som kan innehålla egna mappar.
Av de fyra kombinationerna är den enda som väljer allt som är kapslat under en specifik CSS-förälder CSS-efterkommande väljare. Det finns tre andra kombinerare.
- Barnväljaren (‘>’ istället för enstaka mellanslag) väljer bara element som den första väljaren hänvisar till i en kombinator. Om den första väljaren är (div) och den andra väljaren är (p), väljs endast (p) så länge den har (div) som en förfader. Om ett stycke skapas under ett nytt (avsnitt), även om det är i samma (div), behålls inte stilreglerna.
- Den angränsande syskonväljaren ('+' istället för ett mellanslag) väljer bara det element som ligger närmast den andra väljaren i kombinationsenheten. Om den första väljaren är (div) och den andra väljaren är (p), väljs det första elementet som använder (p) men inte (div).
- Den allmänna syskonväljaren ('~' istället för ett mellanslag) väljer alla element utom de som den andra väljaren hänvisar till. Om den första väljaren är (div) och den andra väljaren är (p), väljs varje element som inte är (p).
Hur ser en CSS-efterkommande väljare ut?
I följande exempel på två olika CSS-efterkommande väljare som arbetar sida vid sida är (div) den första väljaren i den första kombinatorn, medan (ul) är den första väljaren i den andra kombinator. I båda CSS-efterkommande väljare används (p) som den andra väljaren.
Stilelementen skiljer sig mellan (div) och (ul), men (p) bär tydligt egenskaperna hos sin CSS-förälder i båda fallen.
Varför använda en CSS Descendant Selector?
För att förstå vikten av CSS-efterkommande väljare är det värdefullt att först förstå CSS-kapslade väljare.
Vi vill generellt att vissa stilregler ska tillämpas på hela webbplatsen, till exempel den specifika storlek eller typsnitt som all stycke (p) -text använder som standard. På samma sätt kan HTML börja se rörigt ut om dessa stilregler tillämpas för varje enskilt stycke snarare än för hela webbplatsen.
Kapslad CSS är möjlig genom användning av CSS-kombinerare, såsom CSS-efterkommande väljare. Genom att "häcka" CSS under en förälderväljare är det möjligt att snabbt och effektivt berätta för en webbplats hur en specifik väljare ska se ut i varje scenario som CSS-föräldern hänvisas till.
Med hjälp av en kapslad CSS-väljare kan vi använda samma regler för att utforma flera delar av en webbplats samtidigt, vilket gör att vi kan klara oss med mindre arbete samtidigt som vi håller vår HTML ren och ren.