Отримати ідентифікатор сторінки за шаблоном


19

Хочу знати, чи можна отримати ідентифікатор сторінки з певним шаблоном. Чи можливо отримати ідентифікатор сторінки, призначену "page-special.php"?

Відповіді:


39

Коли сторінка створена, призначений для неї шаблон зберігається як користувацький мета публікації так само, як і власні поля. І meta_keyє, _wp_page_templateі єmeta_value буде шаблон сторінки

Ви можете просто скористатися get_pagesдля отримання всіх сторінок, які мають meta_valueвказаний шаблон

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

EDIT 23-07-2015

Якщо вам просто потрібні ідентифікатори сторінки, ви скористаєтеся get_postsі просто пропустіть pageяк post_typeі 'idsas fields` значення. Це забезпечить набагато швидший і набагато оптимізованіший запит, оскільки ми повернемо стовпчик ідентифікатора повідомлення в db, а не всі для вказаних сторінок

( Потрібна 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>';

Гей, спасибі Це не занадто "важко"? (працює на всіх сторінках)
user3800799

Залежить від кількості ваших сторінок. Насправді немає швидшого рідного способу отримання цих даних. Якщо у вас багато сторінок, я б запропонував використовувати перехідні пристрої для зберігання цих даних і лише видалити / видалити перехідний час, коли опублікується нова сторінка
Pieter Goosen

Моє задоволення, рада, що можу допомогти. Насолоджуйтесь :-)
Пітер Гусен

@ user3800799 Я оновив пост, якщо вас цікавить лише отримання ідентифікаторів, нічого іншого
Пітер Гузен

Ви також можете використовувати set_transient( codex.wordpress.org/Transients_API ), якщо не хочете надто запитувати базу даних.
Кріс Андерссон

2

Якщо шаблон сторінки розташований у підпапках, папках із темами / сторінками-шаблонами / page-template.php, то нижче запит буде працювати:

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

Ці вище коди також відображають підсторінки.

Спасибі


0

Далі йде трохи більш сформульований сценарій, який враховує мову, якщо це потрібно. Зверніть увагу, що він передбачає використання Polylang, а не 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

0

Ось повна функція, яка працює з WPML та Polylang. Кредит на 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'];
    }
}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.