Uzyskaj identyfikator strony według szablonu

19

Chcę wiedzieć, czy można uzyskać identyfikator strony z określonym szablonem. Czy to możliwe, aby uzyskać identyfikator strony przypisanej do „page-special.php”?

użytkownik3800799
źródło

Odpowiedzi:

39

Po utworzeniu strony przypisany szablon do tej strony jest zapisywany jako niestandardowy meta post w taki sam sposób, jak pola niestandardowe. meta_keyJest _wp_page_templatei meta_valuebędzie szablon strona

Możesz po prostu użyć get_pagesdo pobrania wszystkich stron, które mają meta_valueokreślony szablon

$pages = get_pages(array(
    'meta_key' => '_wp_page_template',
    'meta_value' => 'page-special.php'
));
foreach($pages as $page){
    echo $page->ID.'<br />';
}

EDYCJA 23-07-2015

Jeśli potrzebujesz tylko identyfikatorów stron, skorzystaj z, get_postsa następnie po prostu przekaż wartość pagejako post_typei „ aspola identyfikatora” . Zapewni to znacznie szybsze i bardziej zoptymalizowane zapytanie, ponieważ zwracamy tylko kolumnę id id w db, a nie wszystkie z nich dla podanych stron

( Wymaga PHP 5.4+ )

$args = [
    'post_type' => 'page',
    'fields' => 'ids',
    'nopaging' => true,
    'meta_key' => '_wp_page_template',
    'meta_value' => 'page-special.php'
];
$pages = get_posts( $args );
foreach ( $pages as $page ) 
    echo $page . '</br>';
Pieter Goosen
źródło
Hej dzięki. Czy to nie jest zbyt „ciężkie”? (przeglądanie wszystkich stron)
user3800799
Zależy, ile masz stron. W rzeczywistości nie ma szybszego natywnego sposobu na odzyskanie tych danych. Jeśli masz dużo stron, sugerowałbym, abyś użył transjentów do przechowywania tych danych i opróżnij / usuń transjenta tylko po opublikowaniu nowej strony
Pieter Goosen,
Cała przyjemność po mojej stronie, cieszę się, że mogłem pomóc. Ciesz się :-)
Pieter Goosen
@ user3800799 Zaktualizowałem post, jeśli jesteś zainteresowany tylko uzyskaniem identyfikatorów, nic więcej
Pieter Goosen
Możesz także użyć set_transient( codex.wordpress.org/Transients_API ), jeśli nie chcesz zbytnio przesyłać zapytań do bazy danych.
Chris Andersson
2

Jeśli szablon strony znajduje się w podfolderze, theme-folder / page-templates / page-template.php, poniższe zapytanie zadziała:

$page_details = get_pages( array(
 'post_type' => 'page',
 'meta_key' => '_wp_page_template',
 'hierarchical' => 0,
 'meta_value' => 'page-templates/page-template.php'
));

Powyższe kody wyświetlają również podstrony.

Dzięki

Sushil Adhikari
źródło
0

Poniżej znajduje się nieco bardziej wyartykułowany skrypt, który w razie potrzeby uwzględnia język. UWAGA: zakłada użycie Polylang, a nie WPML.

function get_post_id_by_template($template,$lang_slug = null){
  global $wpdb;
  $wh = ($lang_slug) ? " AND t.slug = %s" : "";

  $query = $wpdb->prepare(
    "SELECT DISTINCT p.ID
    FROM $wpdb->posts p
    INNER JOIN $wpdb->postmeta meta ON meta.post_id = p.ID
    INNER JOIN $wpdb->term_relationships tr ON meta.post_id = tr.object_id
    INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id
    INNER JOIN $wpdb->terms t ON tt.term_id = t.term_id
    WHERE p.post_status = 'publish' AND meta.meta_key = %s AND meta.meta_value = %s" . $wh,
    '_wp_page_template',
    $template,
    $lang_slug
  );

  $ids = $wpdb->get_results($query);

  if($ids && isset($ids[0])){
    $p = $ids[0];
    return $p->ID;
  } else {
    return false;
  }
}// get_post_id_by_template
Luca Reghellin
źródło
0

Oto pełna funkcja, która działa z WPML i Polylang. Kredyt na https://github.com/cyrale/

/**
* Search for a page with a particular template.
*
* @param string $template Template filename.
* @param array  $args     (Optional) See also get_posts() for example parameter usage.
* @param bool   $single   (Optional) Whether to return a single value.
*
* @return Will be an array of WP_Post if $single is false. Will be a WP_Post object if the page is find, FALSE otherwise
*/
if (!function_exists('get_page_by_template')) {
    function get_page_by_template($template, $args = array(), $single = true) {
        $pages_by_template = wp_cache_get('pages_by_template', 'cyrale');
        if (empty($pages_by_template) || !is_array($pages_by_template)) {
            $pages_by_template = array();
        }
        if (!isset($pages_by_template[$template])) {
            $args = wp_parse_args(array(
                'posts_per_page' => -1,
                'post_type'      => 'page',
                'suppress_filters'  => 0,
                'meta_query'     => array(
                    array(
                        'key'   => '_wp_page_template',
                        'value' => $template,
                    ),
                ),
            ), $args);
            $pages = get_posts($args);
            $pages_by_template[$template]= array(
                'single' => !empty($pages) && is_array($pages) ? reset($pages) : false,
                'pages'  => $pages,
            );
        }
        wp_cache_set('pages_by_template', $pages_by_template, 'cyrale');
        return $pages_by_template[$template][$single ? 'single' : 'pages'];
    }
}
Alex Vand
źródło