WordPress主题添加幻灯片功能

在 WordPress 主题使用中,有个别的主题并没有幻灯片功能,需要我们手动添加该功能,成本过高,今天给大家…

WordPress 主题使用中,有个别的主题并没有幻灯片功能,需要我们手动添加该功能,成本过高,今天给大家分享一组不错的后台幻灯版发布的代码,同时也可以运用在前台调用,可以说是华丽丽的前端幻灯片了,我们以默认的 wordpress 主题为例,讲解下如何为 wordpress 主题添加一个幻灯片发布功能,我们再 wordpress 主题下创建一个 inc 文件夹,并在该文件夹下新建 post_type.php 文件。
首先创建一个自定义文章类型

  1. add_action('init', 'ashu_post_type');
  2. function ashu_post_type() {
  3.     /**********幻灯片*****************/
  4.     register_post_type( 'slider_type',
  5.         array(
  6.             'labels' => array(
  7.                 'name' => '幻灯片',
  8.                 'singular_name' => '幻灯片',
  9.                 'add_new' => '添加',
  10.                 'add_new_item' => '添加新幻灯片',
  11.                 'edit_item' => '编辑幻灯片',
  12.                 'new_item' => '新幻灯片'
  13.             ),
  14.         'public' => true,
  15.         'has_archive' => false,
  16.         'exclude_from_search' => true,
  17.         'menu_position' => 5,
  18.         'supports' => array( 'title','thumbnail'),
  19.         )
  20.     );
  21. }
  22.  
  23. add_filter( 'manage_edit-slider_type_columns', 'slider_type_custom_columns' );
  24. function slider_type_custom_columns( $columns ) {
  25.     $columns = array(
  26.         'cb' => '<input type="checkbox" />',
  27.         'title' => '幻灯片名',
  28.         'haslink' => '链接到',
  29.         'thumbnail' => '幻灯片预览',
  30.         'date' => '日期'
  31.     );
  32.     return $columns;
  33. }
  34. add_action( 'manage_slider_type_posts_custom_column', 'slider_type_manage_custom_columns', 10, 2 );
  35. function slider_type_manage_custom_columns( $column, $post_id ) {
  36.     global $post;
  37.     switch( $column ) {
  38.         case "haslink":
  39.             if(get_post_meta($post->ID, "slider_link", true)){
  40.                 echo get_post_meta($post->ID, "slider_link", true);
  41.             } else {echo '----';}
  42.                 break;
  43.         case "thumbnail":
  44.                 $slider_pic = get_post_meta($post->ID, "slider_pic", true);
  45.                 echo '<img src="'.$slider_pic.'" width="95" height="41" alt="" />';
  46.                 break;
  47.         default :
  48.             break;
  49.     }
  50. }

然后在 wordpress 主题的 functions.php 文件加入以下代码

  1. require get_template_directory() . '/inc/post_type.php';

就这样后台部分完成,下面是前台内容输出的部分,因为使用不同的幻灯插件会有不同的输出形式,下面只是给大家一个参考:

  1. <?php
  2. $args = array(
  3.     'post_type'=>'slider_type',
  4. );
  5. query_posts($args);
  6. if( have_posts() ) : ?>
  7. <div id="banner">
  8.     <div id="show">
  9.     <?php
  10.     while( have_posts() ) : the_post();
  11.         $image_url = get_post_meta($post->ID,'slider_pic',true);
  12.         if($image_url!=''){ ?>
  13.         <div class="show_item">
  14.             <a href="<?php echo get_post_meta($post->ID,'slider_link',true);?>">
  15.                 <img src="<?php echo $image_url; ?>" alt="<?php the_title(); ?>" />
  16.             </a>
  17.         </div>
  18.     <?php } endwhile; ?>
  19.     </div>
  20. </div>
  21. <?php endif; wp_reset_query(); ?>
类别:WordPress教程

本文收集自互联网,转载请注明来源。
如有侵权,请联系 wper_net@163.com 删除。

评论 (0)COMMENT

登录 账号发表你的看法,还没有账号?立即免费 注册