Um das Artikel- bzw. Beitragsbild in WordPress automatisch zu setzen, können wir uns folgende kleine Funktion zu nutze machen. Der geeignete Ort, um diesen Code in ein WordPress-Theme einzubauen, ist wie bei fast alle hier im Blog vorgestellten Snippets, die functions.php-Datei.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
function beitragsbild_setzen() { global $post; $beitragsbild_vorhanden= has_post_thumbnail($post->ID); if (!$beitragsbild_vorhanden) { $anhang = get_children( "post_parent=$post->ID&post_type=attachment&post_mime_type=image&numberposts=1" ); if ($anhang) { foreach ($anhang as $anhang_id => $bild) { set_post_thumbnail($post->ID, $anhang_id); } } } } add_action('the_post', 'beitragsbild_setzen'); add_action('save_post', 'beitragsbild_setzen'); add_action('draft_to_publish', 'beitragsbild_setzen'); add_action('new_to_publish', 'beitragsbild_setzen'); add_action('pending_to_publish', 'beitragsbild_setzen'); add_action('future_to_publish', 'beitragsbild_setzen'); |
Da Copy&Paste-Programmieren nicht meine Art ist, noch ein paar Worte zur Funktionsweise. Die letzten 6 Zeilen des Snippets sind der Einstiegspunkt. Über „add_action“ wird jeweils ein Zeitpunkt definiert, an dem etwas (die beitragsbild_setzen-Funktion) aufgerufen werden soll.
Die Zeitpunkte sind so gewählt, dass die Funktion immer dann aufgerufen wird, wenn entweder der Beitrag geladen, gespeichert oder veröffentlicht wird. Die eigentliche „Arbeit“ geschieht dann in der beitragsbild_setzen-Funktion.
Zuerst wird mittels der has_post_thumbnail-Funktion geprüft, ob der jeweilige Artikel bereits ein Beitragsbild hat. Nur wenn er keins hat (das ! bedeutet „unwahr“), wird daraufhin nach einem passenden Beitragsbild gesucht. Hierzu wird mittels get_children versucht alle Bilder des Artikels zu laden. Wenn Bilder im Artikel sind, wird daraufhin das Artikelbild mittels der set_post_thumbnail-Methode gesetzt.