Sitemap

Aus DynPG-Wiki
Wechseln zu: Navigation, Suche

Eine Sitemap gibt Besuchern Ihrer Webseite einen Überblick über den gesamten Inhalt. Alle Gruppen und Artikel werden dabei in strukturierter und zumeist hierarchischer Form angezeigt. Eine Sitemap ist neben den Meta-Daten ein weiteres Werkzeug zur Suchmaschinenoptimierung.

Einrichten der Sitemap

In DynPG wird eine Sitemap basierend auf dem Navigationsmenü erstellt. Für die Generierung der Übersicht müssen folgende Schritte durchgeführt werden:

  1. es muss ein dynamisches Navigationsmenü samt zugehörigem Artikel erstellt werden
  2. anschließend wird eine Seite erstellt, welche die Sitemap ausgibt
  3. und zuletzt muss dieser Artikel in die Webseite integriert werden.

Im Folgenden werden wir uns mit diesen drei Schritten befassen und anschließend noch darauf eingehen, wie wir bestimmte Artikel in der Sitemap ausblenden können. Danach können Sie auch das Tutorial - Einbau einer Sitemap lesen, welches diese Schritte nocheinmal beispielhaft durchgeht und einen alternativen Weg für die Einbindung der Sitemap in die Webseite zeigt.

Erstellen des dynamischen Menüs

Sofern Sie noch kein dynamisches Menü erstelt haben, finden Sie hierzu eine ausführliche Anleitung in den folgenden Artikeln:

Sitemap erstellen

Um eine Sitemap zu erstellen, können wir das folgende Snippet verwenden:

Sitemap-Snippet

<?php
// Sitemap Template für die dynamische Navigation setzen
$DynPG->SetParam_PlugIn_Template('DPGdynmenu', 'sitemap');
// Versteckte Gruppen ausblenden
$DynPG->SetParam_PlugIn_Param('DPGdynmenu', 'hide_not_public_groups', TRUE);
// Gruppenbaum expandieren
$DynPG->SetParam_PlugIn_Param('DPGdynmenu', 'full_load', TRUE);
 
$DynPG->SetParam_A_Anytime(true);             // Sitemap immer anzeigen
$DynPG->SetParam_A_CategoryNavigation(false); // Kategorienavigation nicht anzeigen
$DynPG->SetParam_A_PrintNavigation(false);    // Drucken-Button nicht anzeigen
$DynPG->SetParam_A_ArticleHeader(false);      // Artikelkopf nicht anzeigen
$DynPG->SetParam_A_Article(<ID>);             // ID des Artikels setzen, der das dynamische Menü enthält
 
$DynPG->Write_Article();                      // Sitemap ausgeben
?>
Caution.png Achtung: Sie müssen in diesem Snippet noch den Platzhalter <ID> durch die ID des Artikels ersetzen, der die dynamische Navigation enthält.

Hier wird zuerst das Template für die dynamische Navigation auf sitemap gesetzt, was die Ausgabe des Navigationsmenüs als Sitemap bewirkt. Danach werden die versteckten Gruppen ausgeblendet und das Anzeigen aller Gruppen festgelegt.

Sitemap in die Webseite einbinden

Um die Sitemap in Ihre Webseite einzubinden, gibt es verschiedene mögliche Wege. Einer ist die Erstellung einer neuen Webseite. Erstellen Sie dazu eine Kopie der Datei, welche das Layout der Seite festlegt und das dynamische Menü sowie die Inhaltsanzeige einbindet (in der Regel index.php). Benennen Sie die Kopie in sitemap.php um. Erstellen Sie nun im Backend auf der obersten Gruppenebene eine neue Gruppe mit dem Namen Sitemap. Wir müssen nun das dynamische Navigationsmenü so anpassen, das bei einem Klick auf den Menüpunkt Sitemap die Datei sitemap.php aufgerufen wird. In der Datei sitemap.php möchten wir wiederum für alle Menüpunkte außer Sitemap auf die Datei index.php verlinken.

Note.png Bemerkung: Einen anderen Weg zum Einbinden einer Sitemap, der auf das Erstellen einer Kopie verzichtet, finden Sie im Tutorial - Einbau einer Sitemap.

Anpassen der Datei index.php

Um nun für den Menüpunkt Sitemap auf die Datei sitemap.php zu verlinken, müssen wir in dieser Datei folgende Anweisung vor die Ausgabe des Navigationsmenüs schreiben:

index.php - Navigationsmenü

$GLOBALS["DynPG"]->SetParam_PlugIn_Param('DPGdynmenu', 'href_subpages', array(<ID> => '../<Pfad zu ihrer Webseite>/sitemap.php{query}'));
Caution.png Achtung: Sie müssen in dieser Anweisung noch den Platzhalter <ID> durch die ID der Sitemap-Gruppe ersetzen, die Sie zuvor erstellt haben. <Pfad zu ihrer Webseite> muss durch den relativen Pfad zur Datei sitemap.php ersetzt werden, ausgehend vom DynPG Hauptverzeichnis.

Anpassen der Datei sitemap.php

Ersetzen Sie die Inhaltsanzeige, d.h. die Anweisungen $DynPG->Write_AllGroups(), $DynPG->Write_AllArticles(), $DynPG->Write_Article() usw. durch das obige Sitemap-Snippet.

In der Datei sitemap.php schreiben wir nun außerdem folgende Anweisung vor die Ausgabe des Navigationsmenüs, um von dieser Datei wieder zurück auf die Datei index.php zu verlinken:

sitemap.php - Navigationsmenü

$GLOBALS["DynPG"]->SetParam_PlugIn_Param('DPGdynmenu', 'href_page_groups', '../<Pfad zu ihrer Webseite>/index.php');
$GLOBALS["DynPG"]->SetParam_PlugIn_Param('DPGdynmenu', 'href_page_articles', '../<Pfad zu ihrer Webseite>/index.php');
$GLOBALS["DynPG"]->SetParam_PlugIn_Param('DPGdynmenu', 'href_subpages', array(<ID> => '../<Pfad zu ihrer Webseite>/sitemap.php{query}'));
Caution.png Achtung: Sie müssen in dieser Anweisung noch den Platzhalter <ID> durch die ID der Sitemap-Gruppe ersetzen, die Sie zuvor erstellt haben. <Pfad zu ihrer Webseite> muss durch den relativen Pfad zur Datei sitemap.php ersetzt werden, ausgehend vom DynPG Hauptverzeichnis.

CSS anpassen

Um die einzelnen Punkte der Sitemap nun noch entsprechend der Hierarchie einzurücken, können wir die folgende CSS Anweisung zum Stylesheet hinzufügen:

div#sm_course_categories_menu div {
  margin-left:10pt;
}