Sidebar
ein-/ausblenden

Benutzerdefinierte Felder außerhalb des WordPress Loop

Plugin für WordPress SEO

Anzeige

Die benutzerdefinierten Felder werden immer wieder gern eingesetzt, manchmal auch außerhalb des Loop und damit kommt man nicht ohne weiteres an die Daten. Eine Möglichkeit ist das Nutzen eines kleines SQL-Queries und schon stehen die Daten außerhalb des Loop zur Verfügung und die Werte, die man zum Beitrag pflegt, können auch außerhalb des Loop genutzt werden.

Das folgende simple Beispiel dient als Basis und muss an die Bedürfnisse angepasst werden, ebenso kann man eine Funktion dafür erstellen - viel Spaß damit. Genügend Raum zum Ausbau also und eher eine Ablage für mich und andere, als ein Tutorial, wie ich es sonst gern pflege und erkläre.


<ul>
<?php
global $wpdb;

$sql = "SELECT wpposts.*
		FROM $wpdb->posts wpposts, $wpdb->postmeta wppostmeta
		WHERE wpposts.ID = wppostmeta.post_id
		AND wppostmeta.meta_key = 'my-image'
		AND wpposts.post_status = 'publish'
		AND wpposts.post_type = 'post'
		ORDER BY wpposts.post_date DESC LIMIT 3";
	
$pageposts = $wpdb->get_results($sql, OBJECT);

foreach ($pageposts as $post) : setup_postdata($post);  ?>
	<li><a href="<?php the_permalink(); ?>" title="Link to <?php echo get_the_title(); ?>">
		<img src="<?php echo get_post_meta($post->ID, "my-image", $single = true); ?>" alt="<?php echo get_the_title(); ?>" /></a>
	</li>
<?php endforeach; ?>
</ul>

Insofern man über WordPress Zugriff verfügt, also innerhalb WordPress arbeitet oder die wp-load.php eingebunden hat, reicht ein kleiner Zugriff auf den Query von WordPress mit der ID und man kann die Inhalte der benutzerdefinierten Felder laden und sich den umständlichen Select sparen.


global $wp_query;
$post_id = $wp_query->post->ID;
$value = get_post_meta( $post_id, 'Name_of_custom_Field', TRUE );
echo $value; // Ausgabe des Wert zum benutzerdef. Feld

26 Kommentare zu „Benutzerdefinierte Felder außerhalb des WordPress Loop“

  1. 1
    Kommentar von pehbehbeh

    Trotzdem ein guter Tipp, der mir eine Woche früher ein bisschen Zeit gespart hätte. ;-)

    (Kleiner Tippfehler in der WHERE-Zeile: "wpposts.ID" statt "wposts.ID", oder?)

  2. 2
    Kommentar von Frank Bültge

    @pehbehbeh: ja, danke und gefixt

  3. 3
    Kommentar von Basti

    Hi, vielleicht is es noch zu früh für Hirnaktivitäten... Aber was spricht dagegen, es so zu machen:

    ID, 'my-image', true); ?>

    < a href="" title="Link to ">
    < img src="" alt="" />

    ^^ Hab das nicht getestet. Die Leerzeichen vor den "<" hab ich eingefügt, damit die Tags nicht verschluckt werden...

  4. 4
    Kommentar von Basti

    OK. Mein Code wurde trotzdem verschluckt. Die Frage war:
    Was spricht dagegen, das über "get_posts('numberposts=3&meta_key=my-image');" zu machen ?

  5. 5
    Kommentar von Basti

    Kommentar-Hilfe-Leser wissen mehr. Und ich sollt mich vielleicht nochmal schlafen legen :) Sorry für die Kommentar-Schwemme.

    <ul>
    <?php
    $pageposts = get_posts('numberposts=3&meta_key=my-image');
    foreach ($pageposts as $post) {
    setup_postdata($post);
    $my_image = get_post_meta($post->ID, 'my-image', true); ?>
    <li>
    <a href="<?php the_permalink(); ?>" title="Link to <?php echo get_the_title(); ?>">
    <img src="<?php echo get_post_meta($post->ID, "my-image", $single = true); ?>" alt="<?php echo get_the_title(); ?>" />
    < /a>
    </li>
    <?php } ?>
    </ul>

  6. 6
    Kommentar von Frank Bültge

    @Basti: der code wurde geschluckt, bitte maskieren.

  7. 7
    Kommentar von Frank Bültge

    @Basti: nix, es ist nur eine andere Form, du nutzt ja quasi damit den Loop von WP, den der wird via get_posts() angesprochen. Deine Version ist eigentlich schöner, müsste nur mal schauen, wie viele Queries im UNterschied sind, das wäre das ienzige, was ich an Bedenken hätte, wenn es um Performance geht.

  8. 8
    Kommentar von Webstandard-Blog

    Für mich als WordPress-Newbie, ein durchaus hilfreicher Tipp von Dir Frank.

  9. 9
    Kommentar von Peter Löwenstein

    Danke für deinen Tipp.

    Eine Alternative ist auch der Einsatz eines Plugins, wenn es um benutzerspezifische Extrafelder geht. Ich weiss, klingt abgedroschen. Trotzdem finde ich cimyuserextrafields nützlich und gut dokumentiert :
    Englische Dokumentation

  10. 10
    Kommentar von Nicki

    Top! Ich halte eher die Option für nützlich eine Abfrage zu gestallten ob ein bestimmter key vergeben ist - ist dies der Fall, dann können dadurch generell weitere Aktionen "gestartet" werden ... bsp. stylesheets oder javascript einzubinden.

    Bsp: Ich vergebe den key für eine attachment url (bild) - ist der key vergeben (und nur dann) wird im header ein grösseres ladeintensives script (lightbox) eingebunden:

    ID, 'attachment', true);
    if($lightbox) : ?>

    Kombiniert mit deinem Beispiel lässt sich so beispielsweise ein komplexes GRID (via css) ohne frameworks oder grösserer scripte einfach und sicher realisieren.

  11. 11
    Kommentar von Steffanie

    ..immer wieder tolle Hilfen hier im Blog. Ich werde hier noch zu einem Spezi. Leider habe ich noch immer arge Probleme mit Java Script.

  12. 12
    Kommentar von Tobias

    Hey,

    also ich find's einfacher einen neuen Loop mit einem neuen $wp_query Objekt zu bauen. In den meisten Fällen ist die Abfrage mittels der query_posts strings einfacher als eine direkte SQL-Abfrage, finde ich. Und in dem neuen Objekt sind ja auch alle Custom Fields drin.

  13. 13
    Kommentar von Robby

    Funktioniert das auch mit einem Wordtube Code? [media id=xy] Wäre interessant so in der Sidebar des jeweiligen Artikels das passende File wiederzugeben! Oder gibts da eine alternative?

  14. 14
    Kommentar von Frank Bültge

    @Robby: prinzipiell ja - kann ich aber nicht so sagen, da man auf das Plugin zugreifen muss und ich dies noch nie gemacht habe.

  15. 15
    Kommentar von Basti

    Also Shortcodes kann man auch mit

    <?php
    echo do_shortcode('[media id='.$xy.']');
    ?>

    ausgeben... Vielleicht hilft das ja - ich weiß nicht genau, wie Wordtube aufgebaut ist.

  16. 16
    Kommentar von Robby

    @Frank & Basti
    Eben alle Varianten durchgetestet und keine Funktioniert mit dem Wordtube Code. Interessanter Weise funktioniert das noch nicht einmal innerhalb eines Loops und den Benutzerdefinierten Feldern. Nur im Content selbst. Na das wird vielleicht noch gefixt..

  17. 17
    Kommentar von Tobias

    Hallo Robby,

    bei mir hat das mit einer älteren Version von Wordtube und WP glaube ich mal mit

    $video = get_post_meta($post->ID, 'Video', true);
    echo apply_filters('the_content', $video);

    funktioniert. Bin mir aber nicht so ganz sicher, ob ich Dich richtig verstehe... den shortcode hatte ich als benutzerdefiniertes Feld 'Video' eingegeben.

  18. 18
    Kommentar von merpil

    Hallo Frank,
    ich weiss gar nicht ob meine frage hier passend ist aber als eine WP neulinge lese ich deine blog seite für seite durch und lerne sehr viel. Nun möchte ich auch dieses artikel nutzen um benutzerdefiniertefelder hinzufügen. Ich möchte aber diese customfields nur einblenden wenns gewünscht wird ( eigentlich wie deine sidebar ein- ausblende funktion)

    Gebe es denn dafür einen plugin oder beschreibung? Ich danke dir

  19. 19
    Kommentar von Frank Bültge

    @merpil: das ein/ausblenden passiert via JavaScript, dazu gibt es sehr viele Ansätze, ich mache dies hier mit der Bibliothek jQuery und nutze dort nur eine Funktion dafür. Suche mal nach slide und jquery, hier im Blog und im Netz gibt es da einiges.

  20. 20
    Kommentar von merpil

    @ Danke

  21. 21
    Kommentar von Holger

    Hi an alle, die an dieser Seite gearbeitet haben.
    Manchmal steht man wie ein Ochs vorm Berg und sieht die einfachsten Lösungen gar nicht. In einem solchen Fall ist es dann gut, wenn es noch Leute wie euch gibt. Beide Ansätze finde ich äußerst interessant und konnte diese auf einer meiner Webseiten gut verwenden. Wie sagt man so schön: Man muss nicht alles wissen, sondern nur wissen, wie man es im Internet findet. Nochmals vielen Dank

  22. 22
    Kommentar von Jörg

    Hallo. Und wieder einmal hat mir die Seite hier geholfen...
    Ich hab Stunden versucht über ein query_posts('meta_key=Feldname&order=meta_value'); meine Posts zu sortieren... egal welche Optionen ich rein- oder rausgenommen habe, es ist keine Sortierung erfolgt. Sogar die Sortierung nach title funktionierte nicht!? Ein Entfernen der Option meta_key hatte aber Auswirkungen, weshalb alle Anschein nach die Optionen ja verarbeitet wurden...
    Wie auch immer, die Lösung von Basti in den Kommentaren hat es nun gerichtet! DANKE.

  23. 23
    Kommentar von Philip

    @holger...wo isn der unterschied?

  24. 24
    Kommentar von Markus

    Hallo.. was hat es mit dem "$single = true" auf sich? wofür ist das gut?

  25. 25
    Kommentar von Frank Bültge

    @Markus: ein einziges Resultat, als String in der Rückgabe; ansonsten könnte auch ein Array o.ä. kommen. siehe Codex

  26. 26
    Kommentar von Markus

    @Frank: Ah ok :-) dann ist das also nur eine andere Schreibweise
    ($post->ID, "my-image", true) oder ($post->ID, "my-image", $single = true) beides das gleiche oder? :-) lese ich sonst nochmal selber nach..

    Danke für den informatieven Post!

Kommentare sind geschlossen.