Startseite
  • » Home
  • » Handbuch & FAQ
  • » Showroom
  • » Forum
  • » Drupalchannel
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Themes & Theming ›

[gelöst] primary links mit CSS Sprites

Eingetragen von bu (4)
am 12.03.2010 - 17:32 Uhr in
  • Themes & Theming
  • Drupal 6.x

Hallo Drupal-Gemeinde,

ich möchte gerne meine primary links durch CSS Sprites ersetzen. Im Html-entwurf sieht die Sache wie folgt aus:

ul#sprite_menu {
   list-style: none;
}

ul#sprite_menu li a {
   background-image: url(images/mainmenu_sprite.png);
   display: block;
   float: left;
   height: 35px;
   text-indent: -9999px;
}

ul#sprite_menu li a.Aktuelles {
   background-position: 0 0;
   width: 88px;
}

ul#sprite_menu li a.Aktuelles:hover, ul#sprite_menu li a.Aktuelles:focus {
   background-position: 0 -35px;
   width: 88px;
}

Daraus wird dann im Html dies:

      <ul id="sprite_menu">
       <li><a href="#Aktuelles" class="Aktuelles">Aktuelles</a></li>
      </ul>

Allerdings stehe ich jetzt bezüglich der Umsetzung in Drupal (-> page.tpl.php) ziemlich auf dem Schlauch.

Drupal schmeißt mir jetzt das entgegen:

<div id="primary" class="clear block">
<ul class="links primary-links">
  <li class="menu-293 first"
    <a href="/xxx/?q=aktuelles">Aktuelles</a>
  </li>
<ul>

Habe jetzt einen ziemlichen Knoten im Hirn. Wie müsste ich die page.tpl.php anpassen oder muss das gar woanders geschehen? Mein CSS-Code steht in der style.css - müsste ich da etwas ändern?

Hilfe wäre spitze :) Ich komme grad mit google und Co nicht weiter, falls es da noch Tipps zum Selbststudium gibt, immer her damit.
(was Bob von den Senfmedien veranstaltet, erscheint mir schlüssig, nur wie auf die primary links anwenden?)

‹ Titelausgabe über PHP steuern Menüeinträge im Block "navigation bar" lassen sich nicht verhindern (in subtheme von ZEN) ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Also wenn ich mir das so

Eingetragen von wla (3808)
am 12.03.2010 - 18:49 Uhr

Also wenn ich mir das so ansehe, würde ich einfach den String "ul#sprite_menu" im CSS durch "#primary ul.primary-links" ersetzen.

Beste Grüße
Werner

  • Anmelden oder Registrieren um Kommentare zu schreiben

Lösung

Eingetragen von bu (4)
am 13.03.2010 - 12:19 Uhr

... sieht bis jetzt so aus:

page.tpl.php

        <?php if (!empty($primary_links)): ?>
          <div id="main_menu_wrapper" >
            <?php print theme('links', $primary_links, array('class' => 'links primary-links')); ?>
          </div> <!-- main_menu_wrapper -->
        <?php endif; ?>

CSS

#main_menu_wrapper {
/*Hier darf jeder selbst probieren*/
}

ul.primary-links li a {
   background-image: url(images/mainmenu_sprite.png);
   list-style: none;
   display: block;
   float: left;
   height: 35px;
   list-style: none;
   text-indent: -9999px;
}

ul.primary-links li.menu-293 a { /*1. Link -> Normalzustand*/
   background-position: 0 0;
   width: 88px;
}

ul.primary-links li.menu-291 a { /*2. Link -> Normalzustand*/
   background-position: -88px 0;
   width: 89px;
}

ul.primary-links li.menu-293 a:hover, ul.primary-links li.menu-293 a:focus, ul.primary-links li.menu-293 a.active { /*1.Link*/
   background-position: 0 -35px;
   width: 88px;
}

ul.links li.menu-291 a:hover, ul.primary-links li.menu-291 a:focus, ul.primary-links li.menu-291 a.active { /*2. Link*/
   background-position: -88px -35px;
   width: 89px;
}

Fazit:

  • wer CSS beherrscht ist klar im Vorteil
  • Firebug ist ein verdammt geniales Werkzeug

Kleiner Hinweis: für den active-Status klappts nur mit der Klasse (a.active), nicht mit der Pseudoklasse (a:active).

Falls ich hier irgendwo einen Fehler drin haben sollte, der mir bis jetzt noch nicht auf die Füße gefallen ist, wären Hinweise wünschenswert. Ansonsten hoffe ich, dass diese CSS-Sprite Lösung für das eine oder andere Projekt hilfreich sein kann.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • Modul für Absatznummern / Randnummern
  • Computed_Field Node Objekt bzw. nid?
  • meine Profilbesucher anzeigen?
  • Path-Based Metatags - wofür sind die gut?
  • URLs: Groß- und Kleinschreibung
  • Views Field Language (Spracherkennung der Felder) funktiniert nicht
  • Fataler Fehler nach update auf Drupal 6.24 wg fehlender Funktion in image.inc
  • [gelöst] Danland: Standard-Startseite formatieren
  • Aggregator Modul lässt sich nicht konfigurieren
  • Views Accordion - Header Elemente nebeneinander
  • Freiberuflicher Drupal Profi für Anpassungen (langfristige Kooperation)
  • Registrierung für vorgefertigte User??!!
Weiter

Neue Kommentare

  • CSS mit body-Tag-Klasse präzisieren
    vor 15 Minuten 31 Sekunden
  • Hat niemand eine Idee?
    vor 1 Stunde 8 Minuten
  • Du mußt in Views aber auch
    vor 2 Stunden 2 Minuten
  • Beschreibung
    vor 2 Stunden 15 Minuten
  • Danke für die Antwort und
    vor 2 Stunden 53 Minuten
  • Rechtschreibung
    vor 3 Stunden 23 Minuten
  • Genau so denke ich auch
    vor 3 Stunden 34 Minuten
  • Dank für deine Antwort. Es
    vor 4 Stunden 22 Minuten
  • Danke! Da hätte ich aber auch
    vor 4 Stunden 50 Minuten
  • Frank, könntest du mir bitte
    vor 6 Stunden 3 Minuten

Statistik

Beiträge im Forum: 173983
Registrierte User: 15483

Neue User:

  • Spearoth
  • bwvebb
  • drupal4normi

» Alle User anzeigen

User nach Punkten sortiert:
stBorchert5516
quiptime4713
Tobias Bähr3874
wla3808
md3777
bv3700
Thoor3678
Alexander Langer3282
dereine2635
Exterior2571
» User nach Punkten
Zur Zeit sind 8 User und 45 Gäste online.

Benutzer online

  • Jenna
  • Spearoth
  • Frank Ralf
  • Alexander Langer
  • oteno
  • Carsten Logemann
  • rogerboy
  • StevenB

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Showroom
  • » Forum
  • » Drupalchannel
  • » Übersetzungsserver
  • » Suche

Quicklinks I

  • Infos
  • Drupal Showcase
  • Installation
  • Update
  • Forum
  • Team
  • Verhaltensregeln

Quicklinks II

  • Drupal Jobs
  • FAQ
  • Drupal-Kochbuch
  • Best Practice - Drupal Sites - Guidelines
  • Drupal How To's
  • Bücherecke

Quicklinks III

  • Tipps & Tricks
  • Drupal Theme System
  • Theme Handbuch
  • Leitfaden zur Entwicklung von Modulen

RSS & Twitter

  • Drupal Planet deutsch
  • RSS Feed Drupal Podcast
  • RSS Feed News
  • RSS Feed Planet
  • Twitter Drupalcenter
Drupalcenter Team | Impressum & Datenschutz | Kontakt
Angetrieben von Drupal | Drupal is a registered trademark of Dries Buytaert.
Drupal Initiative - Drupal Association