如何在WordPress中创建自定义发布类型?

通常人们总是错误的将WordPress简单的归类为博客平台,在过去的几年里,WordPress已经发展成了一个强大的内容管理系统(CMS)。WordPress默认自带的主要内容类型有文章和页面两种,不过你可以根据需要创建更多的自定义内容类型,这些自定义内容类型也就是我们说的自定义发布类型。本文我们将为你展示如何在WordPress中创建自定义发布类型,同时也会教你如何灵活的运用它。

WordPress的自定义发布类型是什么?

自定义发布类型就是像文章和页面那样的内容类型。由于WordPress是从一个简单的平台发展到了今天这样一个强大的CMS平台,发布内容的方式一直延续了下来,但是发布类型可以是多种多样的。默认情况下,WordPress自带一下几种发布类型:

  • 文章
  • 页面
  • 附件
  • 修定版本
  • 导航菜单

你可以创建自己的自定义发布类型,然后起一个你认为不错的名字。例如,如果你正在运营一个影评类的网站,那么你可能想创建一个电影评论的内容发布类型。这个发布类型有不同的自定义栏目,甚至有自己的自定义目录结构。其他的发布类型例子还有:Portfolio, Testimonials, Products等。

创建自定义发布类型之自动篇

在WordPress里创建自定义发布类型最简单的方法就是使用插件。非常推荐WordPress小白们使用这种方法,因为安全还超级简单。

首先你需要安装并启用Custom Post Type UI插件,启用后,插件会在管理员后台左侧边栏添加一个菜单项叫“CPT UI”。

点击“CPT UI” – “Add/Edit Post Types”来创建一个新的自定义发布类型。

Custom Post Type UI插件还可以让你创建自定义分类。

在自定义发布类型页面,你需要给给你自定义发布类型起一个别名,不超过20个字符,例如:movies, recipe, deal, glossary等

在下一个条目里,你需要给你的自定义发布类型定义一个标签,这个标签将会出现在管理员后台的侧边栏目录里,就像文章和页面一样。如果你也是用英文,那么还要区别复数和单数。单数形式的标签将会被WordPress显示在说明以及其他用户界面上。

点击“Add Post Type”按钮,你的自定义发布类型就创建好了。

当然你还可以继续往下滚动屏幕,下面有一些高级的设置可以用来自定义发布类型。

创建自定义发布类型之手动篇

使用插件的一大问题是当插件被禁用后你的自定义发布类型就会消失不见了。你在自定义发布类型里存储的数据都还在,但是这个自定义发布类型已经从系统中注销了,并且从管理员后台界面也无法访问。

如果你是在给客户搭建网站并且不想安装其他的插件,那么你可以通过在主题的functions.php文件或站点插件专用文件中添加代码来手动创建自定义发布类型。

首先,我们先给你展示一种快速且完全有效的例子,这样你可以理解它的工作原理。看一下下面的代码:

// Our custom post type function
function create_posttype() {
 
    register_post_type( 'movies',
    // CPT Options
        array(
            'labels' => array(
                'name' => __( 'Movies' ),
                'singular_name' => __( 'Movie' )
            ),
            'public' => true,
            'has_archive' => true,
            'rewrite' => array('slug' => 'movies'),
        )
    );
}
// Hooking up our function to theme setup
add_action( 'init', 'create_posttype' );

这段代码的作用是用一组参数将发布类型“movies”注册到系统中。这些参数是我们自定义发布类型的选项。数组包括两部分,第一部分是标签,它本身又是一个数组。第二部分包含其他的参数,例如可见性(public visibility)、是否归档(has archive)以及该发布类型的URL中将会用到的别名(slug)。

现在我们来看看可以给你的自定义发布类型添加更多选项的详细代码。

/*
* Creating a function to create our CPT
*/
 
function custom_post_type() {
 
// Set UI labels for Custom Post Type
    $labels = array(
        'name'                => _x( 'Movies', 'Post Type General Name', 'twentythirteen' ),
        'singular_name'       => _x( 'Movie', 'Post Type Singular Name', 'twentythirteen' ),
        'menu_name'           => __( 'Movies', 'twentythirteen' ),
        'parent_item_colon'   => __( 'Parent Movie', 'twentythirteen' ),
        'all_items'           => __( 'All Movies', 'twentythirteen' ),
        'view_item'           => __( 'View Movie', 'twentythirteen' ),
        'add_new_item'        => __( 'Add New Movie', 'twentythirteen' ),
        'add_new'             => __( 'Add New', 'twentythirteen' ),
        'edit_item'           => __( 'Edit Movie', 'twentythirteen' ),
        'update_item'         => __( 'Update Movie', 'twentythirteen' ),
        'search_items'        => __( 'Search Movie', 'twentythirteen' ),
        'not_found'           => __( 'Not Found', 'twentythirteen' ),
        'not_found_in_trash'  => __( 'Not found in Trash', 'twentythirteen' ),
    );
     
// Set other options for Custom Post Type
     
    $args = array(
        'label'               => __( 'movies', 'twentythirteen' ),
        'description'         => __( 'Movie news and reviews', 'twentythirteen' ),
        'labels'              => $labels,
        // Features this CPT supports in Post Editor
        'supports'            => array( 'title', 'editor', 'excerpt', 'author', 'thumbnail', 'comments', 'revisions', 'custom-fields', ),
        // You can associate this CPT with a taxonomy or custom taxonomy. 
        'taxonomies'          => array( 'genres' ),
        /* A hierarchical CPT is like Pages and can have
        * Parent and child items. A non-hierarchical CPT
        * is like Posts.
        */ 
        'hierarchical'        => false,
        'public'              => true,
        'show_ui'             => true,
        'show_in_menu'        => true,
        'show_in_nav_menus'   => true,
        'show_in_admin_bar'   => true,
        'menu_position'       => 5,
        'can_export'          => true,
        'has_archive'         => true,
        'exclude_from_search' => false,
        'publicly_queryable'  => true,
        'capability_type'     => 'page',
    );
     
    // Registering your Custom Post Type
    register_post_type( 'movies', $args );
 
}
 
/* Hook into the 'init' action so that the function
* Containing our post type registration is not 
* unnecessarily executed. 
*/
 
add_action( 'init', 'custom_post_type', 0 );

正如你看到的,我们给自定义发布类型添加了更多的选项,可以添加更多的功能,例如支持修定版本,特色图片,自定义栏目等。

我们甚至还将自定义类型与一个名叫genres的类别关联了起来。另外要注意我们将层次结构(hierarchical)设置为了False。如果你希望你的自定义发布类型像页面一样,你可以把这个值设置为True。

另请注意重复使用的twentythirteen,这叫文本域。 如果你的主题是翻译过的并且你也想把自定义发布类型相关的文字也进行翻译,那么你需要标注主题使用的文本域。 文本域可以在主题目录中的style.css文件的header部分找到。

在网站上显示自定义发布类型

WordPress本身是支持显示自定义发布类型的,当你在自定义发布类型中添加一些内容后,它们就会在网站上显示出来。

这里有一些方法可以试用,每种方法都有自己的优点。

使用默认的归档模板显示自定义发布类型

首先你可以在“外观” – “菜单”中给菜单添加一个自定义链接,这个链接是连接到你的自定义发布类型的,如果你使用了对SEO友好的固定链接,那么你的链接看起来跟下面的类似:

http://example.com/movies

如果你没有使用固定链接,那么你的链接看起来就是这样的:

http://example.com/?post_type=movies

将example.com换成你自己的域名,movies换成你的自定义发布类型的名字。保存菜单然后访问你的网站,你会看到刚刚添加的新菜单。点击菜单后将会显示使用主题默认归档模板的自定义发布类型归档页面。

使用自定义模板显示自定义发布类型归档页和内容详情页

如果你不喜欢默认模板的外观,那么你可以对自定义发布类型使用专属的模板。你所需要做的就是在主题文件夹内创建一个新文件并命名为archive-movies.php。将movies换成你自己自定义发布类型的名字。

你可以先把主题默认的archive.php文件中的内容复制到新文件中,然后开始修改代码来达到自己预期的效果。现在再打开自定义发布类型的归档页面,就会使用新的模板来展示了。

同样,你也可以为单篇内容详情页创建一个自定义模板。在主题目录中新建一个single-movies.php的文件,别忘了了把movies换成你自己的名字。

然后将主题single.php模板中的内容复制到single-movies.php中,再对代码进行修改,直到自己满意。

在首页显示自定义发布类型的内容

使用自定义发布类型的一大优点就是它可以把自定义内容类型跟普通的文章区分开。不过,如果你希望将它们与普通的文章放在一起显示,那么你将下面的一段代码添加到主题的functions.php文件或者站点插件专用文件中:

add_action( 'pre_get_posts', 'add_my_post_types_to_query' );
 
function add_my_post_types_to_query( $query ) {
    if ( is_home() && $query->is_main_query() )
        $query->set( 'post_type', array( 'post', 'movies' ) );
    return $query;
}

别忘了把movies换成你自己的名字。

查询自定义发布类型

如果你熟悉写代码,想在模板中将自定义发布类型的内容循环出来,那么下面是实现方式:

通过查询数据库,你可以从自定义发布类型中获取具体的条目。

<?php $args = array( 'post_type' => 'movies', 'posts_per_page' => 10 );
$the_query = new WP_Query( $args ); 
if ( $the_query->have_posts() ) : while ( $the_query->have_posts() ) : $the_query->the_post(); ?>

<h2><?php the_title(); ?></h2>

<div class="entry-content">
<?php the_content(); ?> 
</div>

<?php wp_reset_postdata(); ?>
<?php else: ?>


<?php _e( 'Sorry, no posts matched your criteria.' ); ?>

<?php endif; ?>

在上面的代码中,我们先为new WP_Query类的参数定义了发布类型和每页显示的条目数。然后我们进行数据查询,获取到内容并将它们显示在循环中。

在小工具中显示自定义发布类型

在WordPress小工具中默认有一个可以显示最近文章的小工具,但是这个小工具无法显示自定义发布类型的内容。如果你想把新发布的自定义类型的内容显示在小工具中该怎么办呢?有一个简单的办法可以实现。

首先安装并启用Ultimate Posts Widget插件,启用后,前往“外观” – “小工具”,将Ultimate Posts小工具拖拽到侧边栏中。这个强大的小工具可以让你显示任何发布类型最新的文章内容,而且还可以显示带有“阅读更多”链接的内容摘要,甚至还能在标题旁边显示特色图片。通过选择你需要的选项来对小工具进行配置,保存后就可以在网站前台看到实际的效果了。

希望本文可以帮助你了解如何在WordPress中创建自定义发布类型。

为您推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注