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 (9461)
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

  • 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
  • Composer nach Umzug
  • [gelöst] Taxonomie Begriffe zeigt nicht alle Nodes an
  • Drupal 11 + Experience Builder (Canvas) + Layout Builder
  • Welche KI verwendet ihr?
  • Update Manger läst sich nicht Installieren
Weiter

Neue Kommentare

  • melde mich mal wieder, da ich
    vor 1 Woche 2 Tagen
  • Hey danke
    vor 1 Woche 3 Tagen
  • Update: jetzt gibt's ein
    vor 1 Woche 4 Tagen
  • Hallo, im Prinzip habe ich
    vor 2 Wochen 1 Tag
  • Da scheint die Terminologie
    vor 2 Wochen 1 Tag
  • Kannst doch auch alles direkt
    vor 2 Wochen 5 Tagen
  • In der entsprechenden View
    vor 2 Wochen 5 Tagen
  • Dazu müsstest Du vermutlich
    vor 2 Wochen 5 Tagen
  • gelöst
    vor 5 Wochen 2 Tagen
  • Ja natürlich. Dass ist etwas,
    vor 5 Wochen 3 Tagen

Statistik

Beiträge im Forum: 250233
Registrierte User: 20450

Neue User:

  • Mroppoofpaync
  • 4aficiona2
  • AppBuilder

» Alle User anzeigen

User nach Punkten sortiert:
wla9461
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 21 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