欢迎光临 - 我的站长站,本站所有资源仅供学习与参考,禁止用于商业用途或从事违法行为!

wordpress教程

wordpress开发教程:获取当前文章的前几篇以及后几篇文章

wordpress教程 我的站长站 2016-08-15 共204人阅读

previous_posts_link()与next_post_lnik()这两个函数相信各位wordpress主题开发者一定不陌生,这两个函数是wordpress用来调用当前文章的前一篇以及后一篇文章的。但是有些时候我们为了提高网站PV提高用户体验想多调用几篇文章,例如调用当前文章的前三篇文章以及后三篇文章那该怎么调用呢?魔客吧查看了下wordpress的官方文档,显然没有现成的代码和函数可用。那么只好自己动手丰衣足食了。以下代码参考自wordpress默认函数get_adjacent_post函数修改而来:

function v7v3_get_post( $previous = true, $number = 1 ) {   
    
   //global当前文章变量 $post 和数据库操作类wpdb   
   global $post, $wpdb;   
   if ( empty( $post ) )   
       return null;   
    
   $current_post_date = $post->post_date;//当前文章的时间   
    
   $join = '';   
   $posts_in_ex_cats_sql = '';   
   //加入表   
   $join = " INNER JOIN $wpdb->term_relationships AS tr ON p.ID = tr.object_id INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id";   
   //获取当前文章所属分类,可以同属多个分类,如果是自定义的分类法,将category换成对应的分类法即可   
   $cat_array = wp_get_object_terms($post->ID, 'level', array('fields' => 'ids'));   
   $join .= " AND tt.taxonomy = 'level' AND tt.term_id IN (" . implode(',', $cat_array) . ")";   
    
   //判断时间是大于还是小于   
   $op = $previous ? '<' : '>';   
   //排序   
   $order = $previous ? 'DESC' : 'ASC';   
         
   $where = $wpdb->prepare("WHERE p.post_date $op %s AND p.post_type = %s AND p.post_status = 'publish' ", $current_post_date, $post->post_type);   
   $sort  = "ORDER BY p.post_date $order LIMIT 0, $number";   
    
   $query = "SELECT p.* FROM $wpdb->posts AS p $join $where $sort";   
   $query_key = 'adjacent_post_' . md5($query);   
   $result = wp_cache_get($query_key, 'counts');   
   if ( false !== $result )   
       return $result;   
    
   $result = $wpdb->get_results("SELECT p.* FROM $wpdb->posts AS p $join $where $sort");   
   if ( null === $result )   
       $result = '';   
   wp_cache_set($query_key, $result, 'counts');   
   return $result;   
}

将该函数放在主题的functions.php文件中即可,调用该函数的时候会返回一个数组,使用示例:

本篇教程之前的几篇教程是ID).'" title="'.$postt->post_title .'">'.$postt->post_title .'';   
           };   
           ?>本篇教程之后的几篇教程是ID).'" title="'.$postt->post_title .'">'.$postt->post_title .'';   
           };   
           ?>

   


标签 cms源码
相关推荐
  • cms源码
  • 最新phpcmsv9.6.3系统源码下载
    最新phpcmsv9.6.3系统源码下载

    源码介绍phpcmsv下载截图由于phpcms官方不再维护,大量phpcms用户面临着各种bug风险,由网友自发维护更新phpcmsv9.6.3系统源码。该源码是咋phpcms v9.6.3的镜像基础上进行维护的,提供bug修复、新模块...

    php源码 214 3年前
  • PHP幽梦影视CMS源码 自动采集
    PHP幽梦影视CMS源码 自动采集

    PHP幽梦影视CMS源码,自主开发的一款自动采集影视源码,自动采集资源站最新内容。搜索模块,播放模块,UI也是用大众喜爱的类型。 核心代码已用SG11加密,但不影响使用和二次开发,代码也做了最大的优化,速度...

    php源码 419 3年前
  • ASPCMS 2.7.3网站源码
    ASPCMS 2.7.3网站源码

    ASPCMS 2.7.3网站源码通用标签说明1、基本标签:{aspcms:sitepath} 网站终极目录(可放在二级目录,其它语言则在三级目录){aspcms:languagepath} 语言目录{aspcms:siteurl} ...

    asp源码 263 4年前
  • Asp.Net淘特Cms网站源码
    Asp.Net淘特Cms网站源码

    Asp.Net淘特Cms网站源码安装方法1、在您的sqlserver企业管理器中,新建数据库totnetcms,然后在totnetcms上右键-所有任务-还原数据库-从设备-找到CMS所在文件夹下database目录里的data.bak文件进行还原...

    .net源码 128 4年前
  • 马克斯CMSV3仿快播电影网站源码
    马克斯CMSV3仿快播电影网站源码

    马克斯CMS模板说明本模板支持马克斯CMS3.0网站管理系统使用,模板增加了些新的页面,有最新排行榜,热门排行榜页,自定义页,也需要对马克斯程序比较了解,这样在安装模板时比较容易。网站模板特点一、二级...

    php源码 469 4年前