Title und meta-Tags

: title
: meta description
: meta keywords

Zusammenhänge zwischen den einzelnen Einstellungsmöglichkeiten in Seitenlayout, Seitenstruktur und Artikel.

Es gibt verschiedene Möglichkeiten, den Browser-Titel (browser title) und die meta-Beschreibung “description und “keywords gezielt zu beeinflussen.

Siehe auch: Meta-Tag per frontend_render

Der am häufigsten vorkommende Fall wird die einmalige Vergabe des Browser-Titels in ADMIN → Seitenlayout unter “Seitentitel” sein. Im Feld darunter “Titel hinzufügen” wird eingestellt was im Browser-Titel wie ausgegeben werden soll.

Die “meta description” werden meistens direkt unter Vorlagen in den <head>-Bereich geschrieben. Die hier eingetragenen Informationen erscheinen nun auf jeder Seite.

Ausgabe im Browser:

<meta name="keywords" content="Schlüsselwörter aus Vorlage in head, Wort01, Wort02" />
<meta name="description" content="Description aus Vorlage in head" />

Der title-Tag kann hier nicht angegeben werden, siehe folgender Abschnitt.

Standard nach der Installation:

Ausgabe im Browser-Title

mit den Einstellungen in Seitenlayout:

und Vorlage:

Eintrag in Kategorie:

In ADMIN → Seitenstruktur → Kategorie Haben wir die Möglichkeit in die Felder “Seitentitel” und “Beschreibung der Seitenebene” Einträge für den Browser-Titel und die “meta descriptions” vorzunehmen.

  • Diese Einträge haben nur Gültigkeit, wenn die Artikel im Listenmodus arbeiten, also mehr als ein Artikel in der Kategorie vorhanden ist und die “Anzahl an Top-Artikel” entsprechend gesetzt ist.
    Diese Einträge würden die bisher vorgegebenen überschreiben, wenn der User im FE in der Artikelübersicht steht.

    r442: Diese Einträge werden zusätzlich in den <head> Bereich geschrieben (z.B. doppelte “meta description”, “meta keywords”).
  • Oder in der Vorlage existieren keine Einträge “description” und/oder “keywords”, in diesem Fall werden die Einträge aus der Kategorie eingesetzt.
    Der “title” kann mit einem kleinen Script (siehe unten) ersetzt werden.


Artikelzentrale:

<note> Die meta description aus der Kategorie überschreibt nicht eine vielleicht vorhandene meta description in der Vorlage. Siehe Script. </note>

Ergebnis im Browser:

Eintrag in der Artikel Basisinformation:

Zu jedem Artikel können gezielte Informationen zum “Browser-Titel”, den “meta descriptions” und den “meta keywords” hinterlegt werden.

In ARTIKEL → Artikel bearbeiten → Artikelinformation [EDIT] → Artikel Basisinformation

kann (können) in den Feldern

- “Seitentitel:” der “Browser-Titel”

in
- “Beschreibung:” die “meta description”

und im Feld
- Schlüsselwört. die “meta keywords”

eingetragen werden.


Seitentitel: und Beschreibung:

Diese Informationen übersteuern alle anderen Einträge die vorher gemacht wurden, solange der Artikel in der Detailansicht arbeitet.

Der Modus Artikeldetailansicht wird angesprochen wenn,

  1. Nur ein Artikel innerhalb der Kategorie existiert
  2. Im Artikellistenmodus auf “more…” oder “mehr…” geklickt wird.

Sind mehrere Artikel in dieser Kategorie (Listenmodus) vorhanden weiß das System nicht von welchem Artikel die Infos verwendet werden sollen, in diesem Fall greifen die Einträge aus der Kategorie oder wenn nicht vorhanden der Eintrag aus Seitenlayout für den “Browser-Titel”.

<note> Die “meta description” aus dem Artikel überschreibt nicht eine vielleicht vorhandene “meta description” in der Vorlage. Dazu siehe Script. </note>


Schlüsselwörter:

Die Einträge in Schlüsselwörter haben zwei Funktionen:

  1. Erzeugen des “meta tag keywords”.
  2. Bereitstellen von Suchbegriffen für die interne Suchfunktion.

<note>Zu 1. Die Einträge aus “Schlüsselwörter” werden nur ausgegeben wenn in der Vorlage kein “meta tag keywords” verwendet wird.!!! </note>

Im Artikellistenmodus werden die unterschiedlichen Keywords aller Artikel der Kategorie zusammengefasst.
Bei “more…” oder “mehr…” (Detailansicht) werden die Keywords des angesprochnen Artikels ausgeliefert.


Ergebnis im Browser:

Im einfachen Artikelmodus:

  <meta name="description" content="meta description aus Artikel" />
  <meta name="keywords" content="Artikel, Cat03, Wort01, Wort02" />


Im Artikellistenmodus:

Mit Keywords aus Artikel Cat03-1: “Artikel, Cat03-1, Wort03, Wort04”

  <meta name="description" content="meta description aus Kategorie" />
  <meta name="keywords" content="Artikel, Cat03, Wort01, Wort02, Cat03-1, Wort03, Wort04" />


Script: Seitentitel/Beschreibung/Schlüssel aus Kategorie in den <head> Bereich

Problem:
In der Vorlage stehen in “title”, “meta description” und “meta keywords” Daten, die für bestimmte Seiten (Kategorien) geändert werden müssten.

Bisher war das lediglich durch eine andere Vorlage/Seitenlayout oder durch Einträge im Artikelkopf möglich oder eben “Artikel im Listenmodus” (siehe oben).

Die Idee bei diesem Script besteht darin, dass die Inhalte von “title”, “meta description” und “meta keywords” einfach aus den vorhandenen Feldern der Kategorie genommen und eingesetzt werden.

Ist ein Kategoriefeld mit Werten gefüllt, werden diese übernommen, wenn nicht, bleiben die Werte aus der Vorlage aktiv. Dieses Script überschreibt also vorhandene Werte die in der Vorlage stehen.

Damit das auch funktioniert müssen die Einträge für description und keywords in der Vorlage sauber aufgebaut sein was die Leerzeichen für die Notation im Bezeichner betrifft.

Falsch:

<meta  name= "description"   content=xyz"/>

Richtig:

<meta name="description" content=xyz" />


  • Title aus Kategorie im Feld “Seitentitel:” übernehmen, wenn
    • 1. max. Artikelanzahl < 0
    • 2. Feld Seitentitel: nicht leer
  • DESCRIPTION aus Kategorie aus dem Feld Beschreibung: übernehmen, wenn
    • das Feld “Beschreibung der Seitenebene:” nicht leer ist
    • Vorhandener TAG “description” in <head> wird überschrieben
  • KEYWORDS aus Kategorie aus dem Feld “Schlüsselwört.:” übernehmen (max. 255 Zeichen ohne CMS-Patch), wenn
    • das Feld “Schlüsselwört.:” nicht leer ist
    • Vorhandener TAG “keywords” in <head> wird überschrieben


Datei: template/inc_script/frontend_init/cat_entries_into_head.php

cat_entries_into_head.php

<?php
// ----------------------------------------------------------------------------------------------
// obligate check for phpwcms constants
if (!defined('PHPWCMS_ROOT')) {die("You Cannot Access This Script Directly, Have a Nice Day."); }
// ----------------------------------------------------------------------------------------------
 
/*
 *********************************************************************
 * TITLE aus Kategorie aus dem Feld "Seitentitel:" uebernehmen, wenn
 * 1. max. Artikelanz. < 0
 * 2. Feld "Seitentitel:" nicht leer
 *
 * 14.11.2011 KH: heermann@planmatrix.de
 * *******************************************************************/
 
if ( ($content["struct"][$content["cat_id"]]['acat_topcount'] < 0) AND
    (!empty($content["struct"][$content["cat_id"]]['acat_pagetitle'])) ) {
 
        $content['pagetitle'] = $content["struct"][$content["cat_id"]]['acat_pagetitle'];
}
 
 
/*
 *********************************************************************
 * DESCRIPTION aus Kategorie aus dem Feld Beschreibung: uebernehmen,
 * wenn das Feld "Beschreibung der Seitenebene:" nicht leer ist
 * Vorhandener TAG "description" in <head> wird ueberschrieben
 *
 * 16.11.2011 KH: heermann@planmatrix.de
 * *******************************************************************/
 
if (!empty($content["struct"][$content["cat_id"]]['acat_info'])) {        // is there any content in field categorie description
 
    if (stripos($block["htmlhead"], '<meta name="description"')!==false ) {    // is the meta tag description st in head
 
        preg_match('/\<meta name="description" content=(.+?)\/\>/im', $block["htmlhead"], $match);
 
        if ( isset($match['1']) AND !empty($match['1']) )                // if match found, replace
            $block["htmlhead"] = str_ireplace('<meta name="description" content='.$match['1'], '<meta name="description" content="'.$content["struct"][$content["cat_id"]]['acat_info'].'" ', $block["htmlhead"]);
 
    } else         // is the meta tag description is not set in head, generate a new one
        set_meta('description', $content["struct"][$content["cat_id"]]['acat_info']);
}
 
 
/*
 *********************************************************************
 * KEYWORDS aus Kategorie aus dem Feld "Schluesselwoert.:" uebernehmen,
 * wenn das Feld "Schluesselwoert.:" nicht leer ist
 * Vorhandener TAG "keywords" in <head> wird ueberschrieben
 * Max. 255 Zeichen ohne CMS-Patch
 *
 * 16.11.2011 KH: heermann@planmatrix.de
 * *******************************************************************/
 
if ( !empty($content["struct"][$content["cat_id"]]['acat_keywords']) ) {        // is there any content in field categorie keywords
 
    if (stripos($block["htmlhead"], '<meta name="keywords"')) {                    // is the meta tag keywords set in head
 
        preg_match('/\<meta name="keywords" content=(.+?)\/\>/im', $block["htmlhead"], $match);
 
        if ( isset($match['1']) AND !empty($match['1']) )                         // if match found, replace
            $block["htmlhead"] = str_ireplace('<meta name="keywords" content='.$match['1'], '<meta name="keywords" content="'.$content["struct"][$content["cat_id"]]['acat_keywords'].'" ', $block["htmlhead"]);
 
    } else        // is the meta tag keywords is not set in head, generate a new one
        set_meta('keywords', $content["struct"][$content["cat_id"]]['acat_keywords']);
}
 
 
// *******************************************************************
 
 
?>

Knut Heermann (flip-flop) 2010/05/04 16:12


Script: Beschreibung aus Artikel in den <head> Bereich

Problem: > Man kann ja in den Artikeln meta-descriptions anlegen, die auch wunderbar gezeigt werden. Ich möchte dies jedoch nicht für alle Artikel machen und daher eine Default-Description in der Vorlage hinterlegen. Leider werden dann auf allen Seiten, die im Artikel eine description haben, doppelte meta-descriptions gezeigt.

Forum: default meta description

Lösung:
Description, Keywords und Title sollten eigentlich in jeder Kategorie angelegt werden. Das war wohl die ursprüngliche Idee. In diesem Fall werden diese Werte von den Einträgen im Artikel autom. überschrieben, wenn vorhanden.
Allerdings setzt fast jeder Benutzer diese Werte direkt in die Vorlage ein und das ist mit dem System nicht kontrollierbar.

Das oben gezeigt Script überschreibt die vorhandenen Einträge in <head> mit den Werten aus der Kategorie.

Das hilft uns jedoch auch nicht viel weiter, wenn Daten im <head> vorhanden sind und der Artikel seine Daten dort zusätzlich einträgt.
Also muss ein Script her (in /frontend_render/..) das ähnlich arbeitet wie das oben gezeigte Script (greift schon wesentlich eher an, in /frontend:init/..).

Blöderweise wird in $content['articles'] das DB Feld article_description der Tabelle phpwcms_article nicht mitgeführt, daher braucht es einen zusätzlichen DB Zugriff.
Die ganze Sache darf nur arbeiten wenn der Artikel in Detailmodus dargestellt wird ($aktion[4] = 1).

$aktion[1] beinhaltet die Artikel-ID.


Dieses Script überschreibt vorhandene Werte die in der Vorlage stehen.
Damit das auch funktioniert müssen die Einträge für description und keywords in der Vorlage sauber aufgebaut sein was die Leerzeichen für die Notation im Bezeichner betrifft.

Falsch:

<meta  name= "description"   content=xyz"/>

Richtig:

<meta name="description" content=xyz" />


Datei: template/inc_script/frontend_render/article_entries_into_head.php

article_entries_into_head.php

<?php
/*
 **************************************************************************
 * DESCRIPTION aus Artikel aus dem Feld Beschreibung: uebernehmen in
 * den <head> Bereich wenn das Feld "Beschreibung:" nicht leer ist
 * Der Vorhandener TAG "description" in <head> wird geloescht
 * Das Script arbeitet im Artikel-Detailmodus
 * Datei: template/inc_script/frontend_render/article_entries_into_head.php
 *
 * 25.02.2012 KH: heermann@planmatrix.de
 * ************************************************************************/
 
// ------------------------------------------------------------------------
// obligate check for phpwcms constants
if (!defined('PHPWCMS_ROOT')) {
   die("You Cannot Access This Script Directly, Have a Nice Day."); }
// ------------------------------------------------------------------------
 
 
// Nur wenn in Artikel-Listenansicht und zu ersetzender String vorhanden
if ($aktion[4] == 1)  {    //  Modus article detail (1) sonst article list (0)
 
    if (stripos($block["htmlhead"], '<meta name="description"')!==false ) {    // is the meta tag description in head
 
        // Beschreibung (description) in diesem Artikel vorhanden?
        $article_sql  = "SELECT article_description FROM ".DB_PREPEND."phpwcms_article ";
         $article_sql .= "WHERE article_aktiv =1 AND article_id = ".$aktion[1];
 
        $result = _dbQuery($article_sql);
 
        // Artikelbeschreibung in der DB vorhanden?
        if (isset($result[0]['article_description']) AND !empty($result[0]['article_description'])) {
 
            // Vorhandene description in <head> loeschen
            $block["htmlhead"] = preg_replace('/\<meta name="description"\s*content=.+?\/\>/im', '',$block["htmlhead"]);
        }
    }
 
//        Beschreibung aus Artikel wird autom. eingetragen, bzw. steht nicht in $block["htmlhead"]
 
}
 
?>


Knut Heermann (flip-flop) 2012/02/25 01:30

deutsch/technik/title-und-meta-tags.txt · Last modified: 2018/06/03 18:08 (external edit)
www.planmatrix.de www.chimeric.de Creative Commons License Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0