1. 在 Wordpress主题中显示最热文章的 PHP代码

  1. <?php $result = $wpdb->get_results("SELECT comment_count,ID,post_title FROM
  2.   $wpdb->posts ORDER BY comment_count DESC LIMIT 0 , 10");
  3.   foreach ($result as $post) {
  4.     setup_postdata($post);
  5.     $postid = $post->ID;
  6.     $title = $post->post_title;
  7.     $commentcount = $post->comment_count;
  8.     if ($commentcount != 0) { ?>
  9.       <li><a href="<?php echo get_permalink($postid); ?>" title="<?php echo $title ?>">
  10.   <?php echo $title ?></a> (<?php echo $commentcount ?>)</li>
  11. <?php } } ?>

2. wordpress主题–相关文章代码

  1. <div id="newpost">
  2. <ul>
  3. <?php
  4. $tags = wp_get_post_tags($post->ID);
  5. if ($tags) {
  6. $first_tag = $tags[0]->term_id;
  7. $args=array(
  8. 'tag__in' => array($first_tag),
  9. 'post__not_in' => array($post->ID),
  10. 'showposts'=>10,
  11. 'caller_get_posts'=>1
  12. );
  13. $my_query = new WP_Query($args);
  14. if( $my_query->have_posts() ) {
  15. while ($my_query->have_posts()) : $my_query->the_post(); ?>
  16. <li><a href="<?php the_permalink() ?>" rel="bookmark"
  17. title="Permanent Link to
  18. <?php the_title_attribute(); ?>"><?php the_title(); ?>
  19. </a> </li>
  20. <?php endwhile; } else {echo 'not realate post';} }else {echo 'not
  21. realate post';} ?>

3. Wordpress主题使用 PHP代码输出最新文章

  1. <?php
  2. $limit = get_option('posts_per_page');
  3. $paged = (get_query_var('paged')) ? get_query_var('paged') : 1;
  4. query_posts('showposts=' . $limit=7 . '&paged=' . $paged);
  5. $wp_query->is_archive = true; $wp_query->is_home = false;
  6. ?>
  7. <?php while(have_posts()) : the_post(); if(!($first_post == $post->ID)) : ?>
  8. <ul>
  9. <li><a href="<?php the_permalink() ?>" rel="bookmark" title="Permanent Link to
  10. <?php the_title_attribute(); ?>"><?php the_title(); ?></a></li>
  11. </ul>
  12. <?php endif; endwhile; ?>

4. 最新评论:

  1. <?php
  2. global $wpdb;
  3. $sql= "SELECT DISTINCT ID, post_title, post_password,
  4. comment_ID,comment_post_ID, comment_author, comment_date_gmt,
  5. comment_approved,comment_type,comment_author_url,
  6. SUBSTRING(comment_content,1,30) AScom_excerpt FROM $wpdb->comments LEFT OUTER
  7. JOIN $wpdb->posts ON($wpdb->comments.comment_post_ID = $wpdb->posts.ID)
  8. WHEREcomment_approved = '1' AND comment_type = " AND post_password = " ORDERBY
  9. comment_date_gmt DESC LIMIT 10";
  10. $comments = $wpdb->get_results($sql);
  11. $output = $pre_HTML;
  12. foreach ($comments as $comment) {
  13. $output.= "\n<li>". "<a href=\"" .get_permalink($comment->ID)."#comment-" .
  14. $comment->comment_ID ."\" title=\"on
  15. ".$comment->post_title ."\">".strip_tags($comment->comment_author)."</a>" .
  16. ": ".strip_tags($comment->com_excerpt)."</li>";
  17. }
  18. $output .= $post_HTML;
  19. echo $output;
  20. ?>

5. wordpress主题–相关文章代码

基本sql是这样:$sql = “SELECT p.ID, p.post_title, p.post_date, p.comment_count,
count(t_r.object_id) as cnt FROM $wpdb->term_taxonomy t_t, $wpdb->term_relationships
t_r, $wpdb->posts p WHERE t_t.taxonomy =’post_tag’ AND t_t.term_taxonomy_id =
t_r.term_taxonomy_id AND t_r.object_id = p.ID AND (t_t.term_id IN ($taglist)) AND
p.ID != $post->ID AND p.post_status = ‘publish’ GROUP BY t_r.object_id ORDER BY cnt
DESC, p.post_date_gmt DESC LIMIT $limit;”;
一点一点的解释:term_taxonomy 、term_relationship、posts这三张表存的什么我不多说,网上一般都可以查到,维基百科貌似都有。把他们连起来,做个 sql,注意 group by以及limit,这样就可以提取结果了$related_post = $wpdb->get_results($sql);
之前要把$taglist 做好,利用wp_get_post_tags($post->ID);可以将该篇文章的的 tag 取到一个数组中,然后再链接就可以了 最后怎么处理输出就看个人爱好了,这个功能我写的大概也就十几行,我比较喜欢简短的说,呵呵。

  1. function related_post($limit = 10) {
  2. global $wpdb, $post;
  3. $tags = wp_get_post_tags($post->ID);
  4. $taglist = "'" . $tags[0]->term_id. “‘”;
  5. $tagcount = count($tags);
  6. if ($tagcount > 1) {
  7. for ($i = 1; $i < $tagcount; $i++) {
  8. $taglist .= “, ‘”.$tags[$i]->term_id.”‘”;
  9. }
  10. }
  11. $sql = SELECT p.ID, p.post_title, p.post_date, p.comment_count, count(t_r.object_id) as cnt
  12. FROM $wpdb->term_taxonomy t_t, $wpdb->term_relationships t_r, $wpdb->posts p WHERE
  13. t_t.taxonomy =’post_tag AND t_t.term_taxonomy_id = t_r.term_taxonomy_id AND t_r.object_id =
  14. p.ID AND (t_t.term_id IN ($taglist)) AND p.ID != $post->ID AND p.post_status = publish GROUP
  15. BY t_r.object_id ORDER BY cnt DESC, p.post_date_gmt DESC LIMIT $limit;”;
  16. $related_post = $wpdb->get_results($sql);
  17. $output = “”;
  18. foreach ($related_post as $tmp){
  19. $output .= 这个就看个人爱好了
  20. }
  21. if($output == “”)$output = No Related Post Yet”;
  22. echo $output;
  23. }

  

Wordpress主题中常用代码总结的更多相关文章

  1. wordpress主题制作常用基本的模板及说明

    style.css : CSS(样式表)文件,一般包括主题声明和通用css样式代码 index.php : 主页模板,一般用来做网站的首页 header.php : Header模板,一般是所有页面的 ...

  2. [工作总结]jQuery在工作开发中常用代码片段集锦(1-10)

    1.jQuery,JS实现tab切换 原生JS实现 HTML代码如下: <div class="wrap"> <ul id="tag"> ...

  3. phpcms中常用代码总结

    1.调用数据库模型 $this->db = pc_base::load_model('test_model');//从"phpcms/model/"目录下加载模型类文件 其中 ...

  4. Android 中常用代码片段

    一:AsyncTask 的使用 (1)activity_main.xml <TextView android:id="@+id/tvInfo" android:layout_ ...

  5. LaTeX中常用代码段snippets(持续更新)

    1.displaymath 单行数学环境,不带编号. \begin{displaymath} This\ is\ displaymath\ envirment.\ I\ don 't\ have\ a ...

  6. (转)WordPress常用模板函数 修改或自制WordPress主题必备

    对于很多WordPress新手来说,不懂任何代码的情况下去瞎改WordPress主题,得出的效果往往会出现语法错误之类的东西或效果不尽人意.想要修改 WordPress主题模板文件最基本的当然要懂得H ...

  7. WordPress主题模板层次和常用模板函数

    首页: home.php index.php 文章页: single-{post_type}.php – 如果文章类型是videos(即视频),WordPress就会去查找single-videos. ...

  8. Wordpress 常用代码解释

    1. 最新文章 Wordpress最新文章的调用可以使用一行很简单的模板标签 wp_get_archvies来 实现. 代码如下: <?php get_archives('postbypost' ...

  9. WordPress主题制作导航的N种方法

    在WordPress主 题制作中,导航菜单的制作算是一个重点,已经写好导航菜单的HTML代码,放在WordPress主题中如何动态调用呢?本文将给你介绍几种编写PHP代 码动态实现导航的方法,本文也将 ...

随机推荐

  1. mysql截取字符串

    mysql 字符串截取1.从左开始截取字符串left(str,length)被截取字段,截取长度select left('admin1213',5) from table 2.从右开始截取字符串rig ...

  2. Yii 安装

    // 安装 composer curl -s http://getcomposer.org/installer | php // 把 composer 添加到全局命令 mv composer.phar ...

  3. mvn多模块开发消除重复依赖造成的打包失败

    错误信息: [ERROR] Failed to execute goal on project xiaoyiweifu-core: Could not resolve dependencies for ...

  4. 伪静态(URL重写)

    伪静态在可以使用数据库提供更强大的功能的同时,将很长很复杂的链接变成简短的静态链接形式,迎合搜索引擎方便搜索引擎蜘蛛(Spider)来抓取网页上的相关内容,提高页面被搜索引擎索引收录的比率,为用户提供 ...

  5. HtmlNodeType枚举

    HtmlNodeType是一个枚举,用于说明一个节点的类型. 源代码如下所示: public enum HtmlNodeType { Document = 0, Element = 1, Commen ...

  6. jQuery 序列化表单数据 serialize() serializeArray()

    1.serialize()方法 格式:var data = $("form").serialize(); 功能:将表单内容序列化成一个字符串. 这样在ajax提交表单数据时,就不用 ...

  7. 关于ArcGIS Rest API

    ArcGIS Rest API: 9.3版本: http://resources.esri.com/help/9.3/arcgisserver/apis/rest/index.html 10版本:ht ...

  8. Redhat关闭SELinux和防火墙的办法(转)

    Redhat使用了SELinux来增强安全,关闭的办法为:1. 永久有效修改 /etc/selinux/config 文件中的 SELINUX="" 为 disabled ,然后重 ...

  9. [Oracle] Data Guard 系列(5) - 创建逻辑备库

    在创建逻辑备库之前,必须得先创建物理备库,关于如何创建物理备库,请参考<Data Guard 系列(4) - 在不停主库的情况下创建物理备库>. 1. 在物理备库上停止日志应用服务 SYS ...

  10. Quartz 开源的作业调度框架

    Quartz 是一个开源的作业调度框架,它完全由 Java 写成,并设计用于 J2SE 和 J2EE 应用中.它提供了巨大的灵活性而不牺牲简单性.你能够用它来为执行一个作业而创建简单的或复杂的调度.本 ...