Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Ü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 (9463)
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

  • Dynamische Ansicht von Seiteninhalt (als Tabelle?)
  • Vergabe von Berechtigungen für bestimmte Rollen; mir fehlt der Haken bzw. das „Veröffentlicht“
  • Ich brauche dringen Hilfe zu Updates oder ggf. wwie geht Composer?
  • Medien und andere Daten mit Feeds von Drupal 7 auf Drupal 10 migrieren
  • Rolle erstellen nicht zu finden
  • für drupal11 ein Slider Modul
  • [gelöst] W3CSS Paragraphs Views
  • Drupal 11 neu aufsetzen und Bereiche aus 10 importieren
  • Wie erlaubt man neuen Benutzern auf die Resetseite zugreifen zu dürfen.
  • [gelöst] Anzeigeformat Text mit Bild in einem Artikel, Drupal 11
  • Social Media Buttons um Insteragram erweitern
  • Nach Installation der neuesten D10-Version kein Zugriff auf Website
Weiter

Neue Kommentare

  • Arrrrg. Nix Tabelle :-D /*
    vor 1 Woche 5 Stunden
  • Textboxen mit Tabelle
    vor 1 Woche 12 Stunden
  • Du sollst ja auch keine
    vor 1 Woche 12 Stunden
  • Theme
    vor 1 Woche 12 Stunden
  • Welches Theme benutzt du
    vor 1 Woche 18 Stunden
  • Mit Responsive Raster hatte
    vor 1 Woche 1 Tag
  • Hallo Alex,um das Häkchen
    vor 1 Woche 1 Tag
  • Modul view_unpublished
    vor 1 Woche 2 Tagen
  • Modul "override node options"
    vor 1 Woche 3 Tagen
  • Im Grunde ist dass ein
    vor 1 Woche 5 Tagen

Statistik

Beiträge im Forum: 250270
Registrierte User: 20477

Neue User:

  • Robertnobia
  • AltonRaf
  • JeffreyPaf

» Alle User anzeigen

User nach Punkten sortiert:
wla9463
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 12 Gäste online.

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Ü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

Quicklinks III

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

RSS & Twitter

  • Drupal Planet deutsch
  • 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