Snygga till rubrikerna med jQuery
2008-09-30 - javascript, jquery
0
Jag har lagt till en liten söt jQuery-funktion på sandman.net för att snygga till rubrikerna lite. Den är löjligt enkel. Vi börjar med CSS-koden:
H2 { font-family: Helvetica, Arial, sans-serif; color: #333; text-transform: uppercase; font-weight: bold; font-size: 24px; line-height: 28px; } H2 > DIV { color: #336699; line-height: 33px; font-size: 35px; }
Så H2 får ett visst utseende, och sen om det finns en DIV inuti H2:an så får den ett eget utseende. Så koden:
<H2>Snygga till<DIV>rubrikerna med jQuery</DIV></H2>
Ska alltså se ut så här:
Så här ska det se ut
Och här är jQuery-koden som gör det:
$("H2").each(function(text){ var text = $(this).text(); parts = text.split(" "); if (parts.length > 3){ var first = parts[0] + " " + parts[1]; parts.splice(0, 2); var second = parts.join(" "); $(this).html(first + "<div>" + second + "</div>"); } });
Vad den gör är att den helt enkelt kollar om rubriken innehåller fler än tre ord, och om den gör det så tar den alla ord efter dom två första och lägger till en annan stilmall helt enkelt. Det går ju att anpassa efter eget bevåg förstås. Sen om just detta är snyggt är ju upp till var och en att avgöra.
Vill man inte använda jQuery så kan man faktiskt uppnå en liknande effekt med CSS bara, genom att använda pseudo-elementet "first-line". Då ser CSS-koden ut så här:
H2 { font-family: Helvetica, Arial, sans-serif; color: #003366; text-transform: uppercase; font-weight: bold; color: #336699; line-height: 33px; font-size: 35px; } h2::first-line { font-size: 24px; line-height: 28px; color: #333; }
Vad som händer då är att den första raden av rubriken är mindre och i en annan färg, så man ser bara effekten på långa rubriker som går över på två rader. Jag ville helst att det skulle bara vara på de två första orden så jag valde att testa det med jQuery, får se om jag går tillbaka till CSS-metoden bara senare.
Mer i Tutorials
Expos  Stickies
Bygg MySQLqueries automatiskt
Mail Processing
Snygga till rubrikerna med jQuery
Min feed
Fixa transparenta PNGbilder i Internet Explorer 6
Rkna tid med PHP
Nyckelord: javascript eller jquery
Javascript library converts Flash to HTML5
Skapa snyggare tooltips med jQuery
Snygga till rubrikerna med jQuery
jQuery
Två månader med Keto
Spelbord v3
Mechanical Age map
More shading and water
Första månaden med Keto
Keto
Fotosession: Tabitha
Utebelysning
Återvinningsskåp
Måla om huset
Byggt hylla till vintunnorna
Dodge RAM
Inline-redigering
Drömmen om ett spa
Dags för carport
Survey Island, what is happening?
Golvprov
Gillestugan uppdaterad!
Spelbord v2
Tre billyhyllor blir två
Gymkort
You can't take the sky from me
Högtalare klara!
eklundh.com tar ned skylten
Högtalare bestämda!
Uppgraderingar biorum
Lord of the Rings-maraton
Ergonomiskt som tusan!
Lego Storm Trooper
Fågel Fenix
Två hyllor på badrummet
Hobbyhörna fixad
Hylla bakom soffan
Modellbygge igen!
Porträtt av u/Flattie-Ratty
Porträtt av u/DangDoood
Buy prints of my maps
Hero Dashboard för Descent
3D-printer
Fältsjukhus 616
Ny kaffemaskin
Porträtt av u/elizabeeeef
Jämförelse 135 mm
Nya objektiv
Porträtt av kompis mamma
Använda utrymmet under trappen
Spelbord
Pimpning av köks-ön
Jag saknar min Dodge!
Acrylic drip