在静态HTML页面中显示WordPress帖子 - 添加更多详细信息

时间:2010-07-14 17:08:15

标签: wordpress

我需要在静态HTML页面上添加指向WordPress帖子的链接。我得到了一些有用的信息,但需要更多元素才能完成。

这是我到目前为止的代码:

<?php

$number = 5;
$wordpress_header = "blog/wp-blog-header.php";

      // Include wordpress header   
      if (file_exists($wordpress_header))
       {
         include ($wordpress_header);

        $myposts = get_posts('numberposts=$number&offset=0&category=0');

        echo "<ul class='Bloglinks'>";

        foreach(array_slice($myposts, 0, $number) as $post) 
         {
            echo '<li><a href="';
            the_permalink();
            echo '">';
            the_date();
            echo " ";
            the_title();
            echo '</a></li>';
         }

         echo "</ul>";

       }
       else
       {
         echo "Unable to connect to Wordpress header file.";
         die();
       } 

?>  

这仅显示最近帖子的标题。我需要能够显示以下内容:

<h5>The truth about Lazy Eye</h5>
<p class="blog-info">07.16.10 | <a class="comment-ref">3 Comments</a></p>
<h5>More Adult Learning Problems Linked to Eyes</h5>
<p class="blog-info">06.12.10 | <a class="comment-ref">1 Comments</a></p>
<h5>New Vision Examination Instruments Arrived!</h5>
<p class="blog-info">05.10.10 | <a class="comment-ref">13 Comments</a></p>

2 个答案:

答案 0 :(得分:1)

您应该将函数query_posts()与函数have_posts()和the_post()一起使用。以下是WordPress API的示例:

//The Query
query_posts('posts_per_page=5');

//The Loop
if ( have_posts() ) : while ( have_posts() ) : the_post();
 ..
endwhile; else:
 ..
endif;

//Reset Query
wp_reset_query();

这将遍历您查询过的所有帖子。因此,您只需将get_posts()函数中的查询插入query_posts()函数即可。

编辑:我想如果你想坚持使用get_posts()函数,你必须调用setup_postdata()函数来获取新帖子(source code for the API):

<ul>
    <?php
        global $post;
        $myposts = get_posts('numberposts=5&offset=1&category=1');
        foreach($myposts as $post) :
            setup_postdata($post);
    ?>
    <li><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a></li>
    <?php endforeach; ?>
</ul> 

但我建议改为使用query_posts()函数。

答案 1 :(得分:0)

   <?php
        require($_SERVER['DOCUMENT_ROOT'] . '/wp-load.php');
        $args = array(
        // 'cat' => 3, // Only source posts from a specific category
        'posts_per_page' => 6 // Specify how many posts you'd like to display
        );
        $latest_posts = new WP_Query( $args );
        if ( $latest_posts->have_posts() ) {
        while ( $latest_posts->have_posts() ) {
        $latest_posts->the_post(); ?>

                                    <article class="vertical-item content-padding ls">
                                        <div class="item-media">
                            <img src="<?php the_post_thumbnail() ?>" alt="<?php the_title(); ?>">
                                        </div>
                                        <div class="item-content">
                                            <h4 class="entry-title">
                                                <a href="<?php the_permalink(); ?>"><?php the_title(); ?></a>
                                            </h4>
                                            <div>

                                                <div class="media-body media-middle greylinks">

                                                    <br><a class="small-text" href="#"><?php the_time('l jS F, Y') ?></a>
                                                </div>
                                            </div>
                                        </div>
                                        <div class="item-footer">

                                            <a class="lato lightgrey weight-black" href="<?php the_permalink(); ?>">Read this Article</a>
                                        </div>
                                    </article>
                                    <? }
        } else {
        echo '<p>There are no posts available</p>';
        }
        wp_reset_postdata();
        ?>