Lista stil css färg. Hur ändrar man färgen på markörer i en lista? Listmarkör typ list-style-type

För att på något sätt skilja raderna i en punktlista från huvudtexten kan du göra färgen på punkterna i listan annorlunda än färgen på texten.

Standard är en svart prick. Om du helt enkelt ställer in färgen på li-elementet kommer ingenting att fungera - färgen kommer att ställas in på hela linjen, och du behöver bara ändra färgen på markören (ul li färg på prickarna).

Hur man ändrar kulfärg med CSS

  1. Döljer de ursprungliga listmarkörerna med hjälp av egenskapen list-stil-typ
  2. Lägga till dina egna markörer med hjälp av ett pseudoelement :innan och fastigheter innehåll. Detta gör att du kan infoga valfri text eller symbol före elementet li.
  3. Markörens utseende kan styras genom CSS-stilar, ändra färg, teckensnitt, bakgrund och mer. Jag använde fet Montserrat-typsnitt.
li ( list-style-type: none; /* Dölj standardmarkörer */ ) li:before ( font-family: "Montserrat", sans-serif; font-weight: 400; color: #d7002e; /* Marker color * / innehåll: " "; /* Markör */ padding-right: 7px; /* Indrag från markör till text */ )

Om du har en situation där markörer dyker upp på onödiga ställen, till exempel i huvudmenyn eller i en dubblettmeny i sidfoten, så kan detta enkelt fixas. Lägg bara till det föräldraelement, som innehåller listor vars markörfärger vi behöver ändra. Jag lade till ordet artikel och nu gäller dessa ändringar endast för innehållsområdet på webbplatsen.

artikel li ( list-stil-typ: ingen; /* Dölj standardmarkörer */ ) artikel li:before ( font-family: "Montserrat", sans-serif; font-weight: 400; color: #d7002e; /* Marker color */ content: " "; /* Marker */ padding-right: 7px; / * Indrag från markör till text */ )

Det finns två populära sätt att ändra färgen på kulorna så att den skiljer sig från textfärgen.

Användande

Inuti varje element

  • vi investerar , och sedan placerar vi texten i den. Med andra ord istället för det traditionella systemet

  • text
  • skapa en design

  • text
  • I det här fallet bestäms färgen på markörerna av färgstilsegenskapen för li-väljaren, och textfärgen bestäms av spanväljaren (exempel 1).

    Exempel 1: Använda kapslade taggar

    Färg på text och punkter i listan

    • Fiol
    • Gitarr
    • Säckpipor
    • Orgel orgel
    • Celesta

    Resultatet av detta exempel visas nedan (Figur 1).

    Ris. 1. Markörer som skiljer sig i färg från huvudtexten

    Trots sin enkelhet är metoden obekväm, särskilt med voluminösa listor, för nu måste du lägga till varje listobjekt .

    Användning::före

    Poängen är denna: vi tar bort de ursprungliga listmarkörerna genom egenskapen list-style-type och lägger till våra egna markörer med ::before pseudo-elementet och content-egenskapen. Denna länk låter dig infoga vilken text eller symbol som helst före ett element, i det här fallet

  • . Dessutom kan typen av text (färg, teckensnitt, bakgrund, etc.) också styras genom stilar, som visas i exempel 2.

    Exempel 2: Använda pseudoelementet ::before

    Listmarkörsfärg

    • Norr
    • söder
    • Väst
    • Öst

    Resultatet av detta exempel visas i fig. 2.

    Artikeln presenterar flera metoder som låter dig ställa in en specifik markör för en onumrerad lista, och indikerar också deras fördelar och nackdelar

    Om du analyserar någon sida kan du upptäcka det faktum att innehållet mycket ofta innehåller listor av olika slag: menyer, produktlistor etc. I HTML-koden ansvarar taggen för en numrerad lista och taggen för en punktlista. lista.

    Det är också värt att notera att punktlistor i praktiken är mycket vanligare, men de har en liten nackdel. Markören i listan visas olika beroende på vilken webbläsare du använder. För en seriös designer är detta ett problem.

    För att eliminera denna negativa effekt måste du avbryta markörutmatningen med egenskapen list-style:

    ol, ul ( liststil: ingen; )

    Detta börjar bildandet av en lista med unika markörer och ikoner. Nedan är de vanligaste sätten att presentera listobjektikoner som är unika och konsekventa i alla webbläsare.

    Markörer genom bilder

    Det vanligaste och enklaste sättet att ange en markör för en lista är att använda en bakgrundsbild (bakgrundsegenskapen). Metoden bygger på att man i stiltabellen specificerar bakgrundsbilden för listobjekten, samt utfyllnadsegenskapen, som reserverar utrymme för den nya markören. Nedan är ett kodexempel:

    ul ( liststil: ingen; ) li( bakgrund: url(sökväg till bild) ingen upprepning; utfyllnad vänster: 20px; )

    Denna metod är nöjd med sin unikhet, eftersom den låter dig ställa in absolut vilken markör som helst i form av en bild. Nedan är hur vår kod kommer att se ut i webbläsaren:

    Den huvudsakliga positiva sidan av denna metod är att den är 100% kompatibel med flera webbläsare, men trots detta finns det en liten nackdel. Att använda en bild är ett extra anrop till servern.

    Markörer som används tidigare

    Det finns ett alternativ när du kan klara dig utan en bild, om designförhållandena tillåter det. Detta är mycket ofta tillåtet när man utformar huvudinnehållet, när listan är markerad med de enklaste elementen, som en kvadrat ( ) eller en pil ( →). Därmed har vi kommit till punkten att vilken lämplig specialkaraktär som helst kan fungera som en markör.

    Därefter uppstår frågan om hur man infogar specialtecken i listelement. Naturligtvis inte för hand, annars skulle det bli en mycket utdragen och tråkig process, plus att det också skulle vara arbetskrävande. Ett pseudoelement hjälper oss att ta oss ur den här situationen innan, vars användning är knuten till en specifik väljare, vilket gör att vi kan automatisera vår process för att tilldela markörer från specialtecken. Denna lösning är lämplig för de flesta webbläsare, med hänsyn till det faktum att för IE kommer den att skrivas uttryck.

    Nedan är ett exempel på kod som skapar en punktlista med ett bindestreck:

    li( this. innerHTML = "-" + this. innerHTML) /*IE hack*/ ) li: before( innehåll: " \201 3" ; }

    I praktiken får vi följande bild:

    Låt mig påminna dig om att hack i verkliga förhållanden är kopplade till villkorliga kommentarer.

    När du använder den här metoden är det viktigaste att känna till kodningen av den nödvändiga ikonen. Det är också värt att notera att för uttryck skrivs specialtecken som en numerisk kombination eller mnemonisk kod. När det gäller innehållsegenskapen placeras i det här fallet ett snedstreck först, och sedan skrivs den hexadecimala koden.

    Använder insertAdjacentHTML

    Ovanstående metod fungerar inte alltid korrekt i den legendariska IE (trots hacket). Mer exakt är "kryckorna" för den här webbläsaren inte fullt utvecklade. En mer effektiv metod bygger på infoga AdjacentHTML, nedan är koden för denna metod:

    li( //z-index: expression(runtimeStyle.zIndex = 1, insertAdjacentHTML("afterBegin", "-")); }

    Markörer ritade av CSS-egenskaper

    Vissa fyrkantiga markörer kan ritas med hjälp av vissa CSS-egenskaper. Till exempel ritas en kvadrat med en färgad fyllning med egenskapen bakgrundsfärg, och en kvadrat i form av en ram ritas med egenskapen kantlinje (förresten, en kvadrat med en fyllning kan ritas på detta sätt) . Exempelpost i en CSS-fil:

    li( //z-index: expression(runtimeStyle.zIndex = 1, detta. innerHTML = "

    " + detta. innerHTML) /* hacka för e6 och 7 */) li: före, . listMarkerBackColor( bakgrundsfärg: #539127; bredd: 7px; höjd: 7px; innehåll: "" ; float: vänster; marginal: 6px 6px 0 0 ; overflow: hidden; ) html . listMarkerBackColor( marginal- höger: 1px; /* fixa en liten bugg i IE6 */ }

    Således kommer en markör ritad med CSS-egenskaper att se ut så här i praktiken:

    Använder före och första barn i kombination

    Denna metod används ofta när man skapar brödsmulor på en webbplats. För de som inte vet vad vi pratar om, titta på exemplet nedan.

    I det här fallet är varje länk separerad från varandra med ett specialtecken, men det ska inte finnas något specialtecken före det första elementet. En pseudoklass hjälper oss med detta förstfödde, som endast kommer åt det första elementet i listan. I koden ska det se ut så här

    HTML

    < ul> < li>< a href= "#" >Hem < li>< a href= "#" >Blogg < li>< a href= "#" >CSS < li>Giltig kod när du använder target= "_blank"

    li:before( innehåll: " \21 92" ; ) li: första barn: före( innehåll: "" ; )

    Det är också värt att notera att denna teknik inte bara används för brödsmulor, utan också för vanliga punktlistor, beroende på designen.

    Vilka webbläsare fungerar det i?

    6.0+ 4.0+ 9.5+ 3.0+ 3.0+ - -

    Slutsatser

    För att sammanfatta kan vi notera det faktum att användningen av före pseudo-elementet är motiverat och rationellt i huvudinnehållet, eftersom det inte finns några särskilda krav på utformningen av listor. Detta kommer i sin tur att minska belastningen på servern, jämfört med alternativet när du använder en bild. Och om du också noterar det faktum att huvudinnehållet kan innehålla många punktlistor, så kan skillnaden bli mer betydande. Men bilder har stor nytta när det gäller designlösningar för markörer.

    CSS-listor— En uppsättning egenskaper som ansvarar för utformningen av listor. Att använda HTML-listor är mycket vanligt när man skapar webbplatsnavigeringsfält. Listobjekt representerar en samling blockelement.

    Du kan använda vanliga CSS-egenskaper ändra utseendet på listmarkören, lägg till en bild för markören, och ändra markörens plats. Markeringsblockets höjd kan ställas in med egenskapen line-height.

    Designa listor med CSS-stilar

    1. Listmarkör typ list-style-type

    Egenskapen ändrar markörtypen eller tar bort markören för punktlistor och numrerade listor. Ärvt.

    list-stil-typ
    Värden:
    skiva Standardvärde. En fylld cirkel fungerar som en markör för listobjekt.
    armeniska Traditionell armenisk numrering.
    cirkel En öppen cirkel fungerar som en markör.
    cjk-ideografisk Ideografisk numrering.
    decimal 1, 2, 3, 4, 5, …
    decimal-ledande-noll 01, 02, 03, 04, 05, …
    georgiska Traditionell georgisk numrering.
    hebreiska Traditionell hebreisk numrering.
    hiragana Japansk numrering: a, i, u, e, o, …
    hiragana-iroha Japansk numrering: i, ro, ha, ni, ho, …
    katakana Japansk numrering: A, I, U, E, O, …
    katakana-iroha Japansk numrering: I, RO, HA, NI, HO, …
    lägre alfa a, b, c, d, e, …
    lägre grekiska Små bokstäver i det grekiska alfabetet.
    lägre latin a, b, c, d, e, …
    lägre-romersk i, ii, iii, iv, v, …
    ingen Det finns ingen markör.
    fyrkant En fylld eller ofylld ruta fungerar som en markör.
    övre alfa A, B, C, D, E, …
    övre-latin A, B, C, D, E, …
    övre-roman I, II, III, IV, V, …
    första Ställer in egenskapsvärdet till standardvärdet.
    ärva Ärver egenskapsvärdet från det överordnade elementet.

    Syntax

    Ul (list-stil-typ: ingen;) ul (list-stil-typ: kvadrat;) ol (list-stil-typ: ingen;) ol (list-stil-typ: lägre-alfa;) Ris. 1. Exempel på utformning av punktlistor och numrerade listor

    2. Bilder för listobjekt list-style-image

    Du kan använda bilder och övertoningsfyllningar som markörer för listobjekt. Ärvt.

    Syntax

    Ul (list-style-image: url("images/romb.png");) ul (list-style-image: linear-gradient(#FF7A2F 0, #FF7A2F 50%, #FFB214 50%);)
    Ris. 2. Designa en punktlista med hjälp av en bild
    Ris. 3. Designa en punktlista med en gradient

    3. Liststil-position

    Den här egenskapen ger möjlighet att placera markören utanför eller inuti innehållet i listobjektet. Ärvt.

    Den här handledningsartikeln kommer att fokusera på att arbeta med listor i CSS, du kommer att lära dig hur du ändrar typen av kula, kulans placering i förhållande till listobjektet, skapar dina egna kulor och till och med ändrar kulans färg.

    Jag tror att du redan vet att HTML 5 använder två huvudtyper av listor (exklusive beskrivningslistor och menyalternativ):