1. <div id="11111"></div>

    1. <div id="11111"></div>

      1. <div id="11111"></div>

        WordPress主题制作全过程(八):制作index.php

        日期: 标签:WordPress教程,主题制作 94 条留言
        如需帮忙改代码,或者WordPress二次开发、PHP网站建设等需求,可联系我购买付费服务:  点此联系我
        文章目录

        前面我们已经制作完成博客所有公用页面sidebar.php、footer.php和header.php,今天开始我们就要制作单独的页面了。现在我们要制作的是索引页index.php,这里我们可以暂时把它理解成主页,但事实上它并不是首页这么简单(点此查看原因)。

        在主页中主要就是文章列表,将你博客上的文章一篇一篇地列出来。你可能已经注意到,主页中每篇文章的样式都是一样的,只是标题、时间、作者和摘要等文字内容不一样而已,嗯!我们制作index.php也只需要一篇文章的html代码,不需要手动地去写那么多文章的html,况且这样也不是动态的内容。我们只需要一个循环就可以将所有文章显示到首页上,循环就是重复做某件事情,这里的循环是重复地输出文章。如果你之前学过任一门计算机程序设计语言的话,就不难理解什么是循环,循环的作用也一想就通,如while,for,foreach......

        在这里插一句,如果你真的想了解如何制作主题,请打开的文本编辑器,跟着我一步一步地操作,一步一步地修改,每做一次修改就刷新一下你的博客看看有什么变化,这样才能够加深你的理解。如果你懒得动手,建议以后的内容就不用看了,看了对你帮助也不大。

        现在开始制作index.php。初始情况下index.php中有三篇文章,打开index.php你可以看到文章的3个标记<!-- Blog Post -->,我们现在其他将两篇文章的代码删除,留下一篇,并将文章摘要去除。修改后的代码是这样的:

        <?php get_header(); ?>
        	<!-- Column 1 /Content -->
        	<div class="grid_8">
        		<!-- Blog Post -->
        		<div class="post">
        			<!-- Post Title -->
        			<h3 class="title"><a href="single.html">Loreum ipsium massa cras phasellus</a></h3>
        			<!-- Post Data -->
        			<p class="sub"><a href="#">News</a>, <a href="#">Products</a> • 31st Sep, 09 • <a href="#">1 Comment</a></p>
        			<div class="hr dotted clearfix"> </div>
        			<!-- Post Image -->
        			<img class="thumb" alt="" src="<?php bloginfo('template_url'); ?>/images/610x150.gif" />
        			<!-- Post Content -->
        			
        			<!-- Read More Button -->
        			<p class="clearfix"><a href="single.html" class="button right"> Read More...</a></p>
        		</div>
        		<div class="hr clearfix"> </div>
        		
        		<!-- Blog Navigation -->
        		<p class="clearfix"> <a href="#" class="button float"><< Previous Posts</a> <a href="#" class="button float right">Newer Posts >></a> </p>
        	</div>
        	<?php get_sidebar(); ?>
        <?php get_footer(); ?>

        从上面的代码可以看出,一篇文章的html骨架就是:

        <div class="post">
        	<!-- Post Title -->
        	<h3 class="title"><a href="single.html">文章标题</a></h3>
        	<!-- Post Data -->
        	<p class="sub"><a href="#">标签1</a>, <a href="#">标签12</a> • 发布时间 • <a href="#">评论数</a></p>
        	<div class="hr dotted clearfix"> </div>
        	<!-- Post Image 文章的缩略图 -->
        	<img class="thumb" alt="" src="<?php bloginfo('template_url'); ?>/images/610x150.gif" />
        	<!-- Post Content -->
        	文章内容
        	<!-- Read More Button -->
        	<p class="clearfix"><a href="single.html" class="button right"> 阅读全文按钮</a></p>
        </div>
        <div class="hr clearfix"> </div>

        不同主题的主题的文章html骨架是不一样的,如果你熟悉html,可以很快地分辨出文章骨架,以上是我们这个主题的骨架,我们将以此为基础给index.php加上动态内容:

        1、添加文章标题

        找到:

        <h3 class="title"><a href="single.html">Loreum ipsium massa cras phasellus</a></h3>

        改成:

        <h3 class="title"><a href="<?php the_permalink(); ?>" rel="bookmark"><?php the_title(); ?></a></h3>

        这里解释一下这几个php函数:

        • <?php the_permalink(); ?>  输出文章的URL链接(参考文档
        • <?php the_title(); ?>  输出文章的标题(参考文档

        2、添加文章标签

        我们很多人在写文章的时候都喜欢添加一些标签,况且侧边栏我们也加入了"标签云",我们的主题应该支持标签。找到:

        <a href="#">News</a>, <a href="#">Products</a>

        改成:

        <?php the_tags('标签:', ', ', ''); ?>

        函数参考:the_tags

        3、添加日期

        找到:31st Sep, 09

        改成:

        <?php the_time('Y年n月j日') ?>

        函数参考:the_time

        关于该函数中 Y n j 获取的日期格式,你可以参考文档(中文),选择你喜欢的时间格式:zh-cn:自定义时间和日期

        可能你看了以上提供的时间和日期文档,还是一头雾水,下面提供几个示例,你就差不多能够依样画葫芦,指定自己喜欢的时间日期格式:

        PHP代码 输出内容
        <?php the_time('Y年n月j日') ?> 1999年5月1日
        <?php the_time('Y年m月d日') ?> 1999年05月01日
        <?php the_time('Y-m-d') ?> 1999-05-01
        <?php the_time('y-m-d H:i:s') ?> 99-05-01 02:09:08

        4、显示评论数

        现在我们来添加评论数代码,查找代码:

        <a href="#">1 Comment</a>

        改成:

        <?php comments_popup_link('0 条评论', '1 条评论', '% 条评论', '', '评论已关闭'); ?>

        该函数会根据文章的评论数量显示不同的文字链接,0 条评论、1 条评论等等,当然能你可以根据自己的爱好定制文字内容。该链接会直接打开对应的文章,并移动到文章的评论区,你可以点此查看效果:2 条评论

        函数参考:comments_popup_link

        5、添加编辑按钮

        如果文章作者已登录,我们将允许他在首页点击对应文章的编辑按钮,就可以直接修改文章,这个功能是可选的,你可以不添加。接上面的评论按钮,我们在其后面添加相应代码:

        <?php comments_popup_link('0 条评论', '1 条评论', '% 条评论', '', '评论已关闭'); ?><?php edit_post_link('编辑', ' • ', ''); ?>

        函数参考:edit_post_link

        6、添加文章内容

        可能有些人喜欢在首页输出全文,而有些人喜欢在首页输出文章摘要,这里提供两种方案,任君选择。查找:<!-- Post Content -->

        将其改成:

        <!-- Post Content -->
        <?php the_excerpt(); ?>

        只要在写文章的时候在"摘要"框内填写摘要,在首页显示的就是摘要,如果不填就输出全文!以下是方案二,用于输出全文,除非你在文章中使用了<!-- more -->,代码修改:

        <!-- Post Content -->
        <?php the_content('阅读全文...'); ?>

        函数参考:

        7、阅读全文

        这里给添加阅读全文链接,如果在6、添加文章内容中你选择了输出全文,本步骤可以忽略,查找代码:

        <a href="single.html" class="button right"> Read More...</a>

        改成:

        <a href="<?php the_permalink(); ?>" class="button right">阅读全文</a>

        8、添加文章循环

        到目前为止,你的首页还只能显示一篇文章,要想输出所有文章,需要我们之前提到的循环。查找代码:

        <!-- Blog Post -->

        改成:

        <!-- Blog Post -->
        		<?php if (have_posts()) : while (have_posts()) : the_post(); ?>

        再查找:

        <div class="hr clearfix"> </div>

        改成:

        <div class="hr clearfix"> </div>
        		<?php endwhile; ?>

        再次查找:

        	</div>
        	<?php get_sidebar(); ?>

        改成:

        		<?php else : ?>
        		<h3 class="title"><a href="#" rel="bookmark">未找到</a></h3>
        		<p>没有找到任何文章!</p>
        		<?php endif; ?>
        	</div>
        <?php get_sidebar(); ?>

        好了,现在查看你的主页,是不是可以显示多篇文章了呢?文章数量取决于你在后台设置每页可显示的文章数量。以上的循环可以简化为以下内容,这样看起来应该比较容易理解了,在endwhile之前不断地输出每篇文章,直至文章数量达到每页显示的最大文章数量;如果你的博客上一篇文章都没有,就会输入无文章提示。

        <?php if (have_posts()) : while (have_posts()) : the_post(); ?>
        	文章html骨架
        <?php endwhile; ?>
        <?php else : ?>
        	输出找不到文章提示
        <?php endif; ?>

        参考文档: The Loop

        9、添加文章分页

        上面你已经看到,每页只能显示部分文章,要想看下一页,就得添加分页。现在查找代码:

        <p class="clearfix"> <a href="#" class="button float"><< Previous Posts</a> <a href="#" class="button float right">Newer Posts >></a> </p>

        改成:

        <p class="clearfix"><?php previous_posts_link('<< 查看新文章', 0); ?> <span class="float right"><?php next_posts_link('查看旧文章 >>', 0); ?></span></p>

        参考函数:

        10、文章缩略图

        对于大部分人来说,不太需要文章缩略图的功能,而且有很多插件可以实现这个功能。这里我们将首页的文章缩略图代码删除:

        <!-- Post Image -->
        			<img class="thumb" alt="" src="<?php bloginfo('template_url'); ?>/images/610x150.gif" />

        另外,还有个存档页面的模板archive.php,跟index.php的制作过程完全一样,只不过需要在functions.php里添加一个函数,这里就不再罗嗦,下载自己看吧,注意:functions.php中的代码已经修改,要想让你的分类、标签等存档页能够正常显示,请下载最新的functions.php覆盖原来的。另外,标签页和分类页支持在该页面顶部显示介绍,前提是你在后台文章标签和分类处要填上了描述。

        好了,到目前这个主题也像个样子了,不过还有很多要完善,后面我们将继续完善!按照惯例,继续提供经过本次修改后的主题文件下载:

        下载此文件

        WordPress主题制作全过程完整列表:

        -- 完 --

        本文采用 「CC BY-NC-SA 4.0」创作共享协议,转载请标注以下信息:
        原文出处:露兜博客 http://www.szeverich.net.cn/create-wordpress-themes-index.html
        露兜
        kaapass@outlook.com  QQ 825533758

        业余编程爱好者,主业是淘宝店主,卖些工艺品,感兴趣可以到我的淘宝店看看(旺旺不提供技术咨询):西西弗sisyphe

        94 条留言

        点此留言
        1 2 3 79
        1. 小白

          我最近就遇到这样的问题了,找了很多答案,终于找到了。为站长点赞

        2. ibuffalo

          perfect : )

          非常好的教程,很用心,讲得也很明白,胜过网上流传一时的 水煮鱼 教程。

          正在边看边学,也想做一个适合我们网站的主题。

        3. wp初学者

          首页的一个???,然后那个??橛斜尘巴?,还有内容,内容我我再后台新建的一个文章获取。请问那个背景图怎么从后台添加,展示到前台,

        4. purron

          你好,我使用 the_tags() 函数后,样式和我之前的css文件不一样了,是什么原因呢?该怎么解决?

          • 露兜

            @purron 谷歌浏览器以及ie最新版都有代码调试工具,一般是按 F12 键就出来了,用这个工具看看the_tags()输出的代码被加上了哪些样式。
            代码调试工具具体怎么用请上网搜索。

        1 2 3

        发表留言

        可以挣钱的游戏 191| 250| 829| 417| 719| 222| 462| 688| 993| 248| 271| 110| 581| 999| 708| 824| 10| 854| 990| 61| 284| 402| 210| 202| 997| 351| 49| 345| 996| 990| 406| 19| 487| 726| 51| 606|