web-dev-qa-db-ja.com

the_permalinkを使ってhrefを<li>にエコーする

私は自分が持っているカスタム投稿タイプから自動的に移入するメニューを作成しようとしています、そしてそれを正しくするのに問題を抱えています。これがコードです。 <img src>のPHPは正しい情報を引っ張って正しい場所に貼り付けています、the_permalinkは正しいURLを引っ張っています、しかしそれはhrefの代わりに<li>タグの上にURLを置いています。

<ul class="product-menu">
              <?php
              $products = new WP_Query(
                $args = array(
                  'post_type' => 'product',
                  'post_status' => 'publish',
                )
              );
              while ( $products->have_posts() ) {
                $products->the_post();
                $post_thumbnail_id = get_post_thumbnail_id();
                $post_thumbnail_url = wp_get_attachment_url( $post_thumbnail_id );
                echo 
                '<li>
                  <a href="' . the_permalink() . '">
                    <img src="' . $post_thumbnail_url . '" alt="' . get_the_title() . '">
                  </a>
                </li>';
              } 
              /* Restore original Post Data */
              wp_reset_postdata();?>
              </ul>
2
mrben522

the_permalink() はすぐに urlを表示して何も返さないので、get_the_permalink()関数を使うべきです。を返します。

5
ScheRas

あなたはエコーするthe_permalinkを使っていたので、あなたはエコーでエコーアウトしました。 get_the_permalinkを使用してURLを返し、そのURLをコードにエコーアウトすることができます。 the_で始まるほとんどのワードプレス関数は直接ページにエコーアウトし、get_の関数は結果を返します。

これでうまくいくはずです。 the_post_thumbnailを使ってワードプレス形式のサムネイル画像を引き出し、ハイパーリンクで問題を更新しました。

<ul class="product-menu">
    <?php

    $args = array(
        'post_type' => 'product',
        'post_status' => 'publish',
    )

    $products = new WP_Query($args);

    while ( $products->have_posts() ) {
        $products->the_post();

        echo '<li><a href="' . get_the_permalink() . '">';

        // check if the post has a Post Thumbnail assigned to it.
        if ( has_post_thumbnail() ) {
            the_post_thumbnail();
        }

        echo '</a></li>';
    } 
    /* Restore original Post Data */
    wp_reset_postdata();

    ?>
</ul>
3
Chris Morris