Bài 11: Custom Post Type trong WordPress

Trong hệ thống WordPress có nhiều thể loại bài viết như:

  • Post (Post Type: 'post')
  • Page (Post Type: 'page')
  • Attachment (Post Type: 'attachment')
  • Revision (Post Type: 'revision')
  • Navigation menu (Post Type: 'nav_menu_item')

Đây là các thể loại mặc định có sẵn sau khi bạn cài đặt WordPress. Vấn đề đặt ra bây giờ là tôi muốn tạo một trang web show video và tin tức thì làm thế nào? Chẵng lẽ sử dụng thể loại post cho cả hai rồi tạo một Metadata cho người dùng chọn mỗi khi đăng bài viết? Điều này là không nên bởi rất khó mở rộng.

Với tình hình như vậy thì Custom Post Type sẽ là từ khóa giải quyết vấn đề này cho bạn đấy.

1. WordPres Custom Post Type là gì?

Custom Post Type trong WordPress là tạo ra một thể loại bài viết mới, như ở bài toan trên thì chúng ta sẽ tạo ra một thể loại tên là video.

Để tạo một Custom Post Type thì chúng ta sử dụng hàm register_post_type() và đưa nó vào một hook action tên là init.

Ví dụ: Tạo một thể loại Video

Bạn tạo file custom-post-type.php nằm trong thư mục includes và require nó vào file wp-learn.php (xem lại các bài 1, 2 để biết cấu trúc folder).

File wp-learn.php.

<?php
/**
Plugin Name: Learn WordPress
Plugin URI: http://freetuts.net
Description: Plugin dùng để học WordPress
Author: Nguyễn Văn Cường
Version: 1.0
Author URI: http://freetuts.net
*/

require 'includes/custom-post-type.php';

Bạn mở file custom-post-type.php lên và nhập vào nội dung sau:

add_action('init', 'create_post_type');

function create_post_type() {
    register_post_type('video', array(
            'labels' => array(
                'name' => __('Videos'),
                'singular_name' => __('Video')
            ),
            'public' => true,
            'has_archive' => true,
        )
    );
}

Bạn đăng nhập vào admin thì sẽ thấy một thể loại xuất hiện trong menu như hình sau:

Làm thế nào mà WordPress có thể làm được như vậy? Mình không cần quan tâm đến nó làm như thế nào mà chỉ quan tâm đến cú pháp của hàm register_post_type() thôi :) Chúng ta cùng tìm hiểu hàm này nhé.

2. Hàm register_post_type trong WordPress

Hàm register_post_type dùng để đăng ký một thể loại bài viết và nó có cấu trúc như sau:

register_post_type( $post_type, $args = array() )

Trong đó:

  • $post_type là tên thể loại, với ví dụ trên thì sẽ là video.
  • $args là danh sác các tham số cấu hình cho thể loại này

Tham số $args bao gồm các thông tin chính sau:

  • label: Tên mô tả số nhiều dùng cho vấn đề dịch thuật
  • labels: Mảng này gồm nhiều phần tử và chức năng chung là chỉnh sửa text trên giao diện
    • name: Text hiển thị trên menu chính của thể loại. Ví dụ như Videos.
    • singular_name: Tên của mỗi bài viết, ví dụ với page thì ta gọi là mỗi Page, với post thì ta gọi là mỗi Post.
    • add_new: Text hiển thị thay thế cho từ Add New
    • add_new_item: Tiêu đề h1 của trang Add New.
    • edit_item: Nhãn hiển thị thay thế cho từ Edit Post hoặc Edit Page
    • new_item:  Text hiển thị thay thế cho từ New Post hoặc New page
    • view_item: Text hiển thị thay thế cho chữ cho đường link xem live trong trang edit (phần slug)
    • search_items: Đoạn text cho button Search bài viết trong admin
    • not_found: Câu thông báo hiển thị khi tìm kiếm không ra bài viết.
    • not_found_in_trash: Câu thông báo hiển thị khi không có bài viết nằm trong mục trash.
    • parent_item_colon: Tìm hiểu sau
    • all_items: Text hiển thị link tất cả bài viết trong main menu của Admin
    • archives: Text hiển thị cho Post Archives hoặc page Archives
    • insert_into_item: Text cho Media Iframe button
    • uploaded_to_this_item: Text cho Media Iframe Filter
    • featured_image: Text cho từ Featured Image
    • set_featured_image: Text cho từ Set featured image
    • remove_featured_image: Text cho từ Remove featured image
    • use_featured_image: Text cho từ Use as featured image
    • menu_name: Tên hiển thị trên menu, nếu không truyền vào thì nó lấy giá trị của key name
    • filter_items_list: Text cho thẻ tiêu đề hiển thị ẩn
    • items_list_navigation: Text cho bảng phân trang tiêu đề ẩn
    • items_list: Text cho bảng tiêu đề ẩn
    • name_admin_bar: Text hiển thị menu trong nút +New nằm trên thanh bar trên cùng của giao diện admin. Bạn hãy hover vào New -> sẽ thấy xuất hiện đường link với nội dung là chữ mà bạn truyền vào và đường link sẽ link tới trang Add New.
  • description: Phần mô tả cho thể loại này
  • public: Nếu có giá trị TRUE thì mới hiển thị trên menu. Sẽ có một số thuộc tính kế thừa từ thuộc tính này như exclude_from_searchpublicly_queryableshow_in_nav_menusshow_ui nếu giá trị các thuộc tính này không được thiết lập
  • exclude_from_search: Nếu có giá trị TRUE thì sẽ loại trừ các bài viết ra khỏi kết quả tìm kiếm bên ngoài frontend
  • publicly_queryable: Cấu hình đường dẫn Query String cho trang Search ngoài frontend.
  • show_ui: Nếu có giá trị TRUE thì sẽ hiển thị giao diện trong admin
  • show_in_nav_menus: Nếu có giá trị TRUE thì nó sẽ hiển thị bên trang quản lý menu.
  • show_in_menu: Nếu TRUE thì sẽ hiển thị trong Admin Menu
  • show_in_admin_bar: Nếu có giá trị TRUE thì sẽ hiển thị một đường link trên thanh Admin Menu Bar (menu nằm trên cùng +New -> Tên Menu)
  • menu_position: Vị trí hiển thị menu trên danh sách menu của admin, giá trị truyền vào là số nguyên bắt đầu từ 1.
  • menu_icon: URL đến Icon của menu
  • supports: Một mảng danh sách các metabox sẽ hiển thị trong trang Add New
  • register_meta_box_cb: Đây là một callback function gọi đến một hàm tạo Meta Boxes nào đó.
  • taxonomies: Một mảng các Taxonomies
  • has_archive: Hiển thị bài viết của thể loại này trong mục ngày tháng năm
  • capability_type: Nhóm quyền mà thể loại này kế thừa, là một mảng và tên quyền sẽ được tạo mới với tên là tên bạn truyền vào, ví dụ:
    'capability_type' => array(
        'edit_post'          => 'edit_video', 
        'read_post'          => 'read_video', 
        'delete_post'        => 'delete_video', 
        'edit_posts'         => 'edit_videos', 
        'edit_others_posts'  => 'edit_others_videos', 
        'publish_posts'      => 'publish_videos',       
        'read_private_posts' => 'read_private_videos', 
        'create_posts'       => 'edit_videos', 
    )
  • capabilities: Nhóm quyền của thể loại này
  • map_meta_cap: Tìm hiểu sau
  • hierarchical: Nếu có giá trị TRUE thì chức năng Attributes của trang sẽ có tác dụng
  • permalink_epmask:
  • rewrite: Cấu hình rewrite URL
  • query_var: Tìm hiêu sau
  • can_export: Cho phép sử dụng tool để export
  • show_in_rest: Hiển thị bài viết thể loại này trong REST API
  • rest_base: Tìm hiểu sau
  • rest_controller_class: Tìm hiểu sau
  • _builtin: Tìm hiểu sau
  • _edit_link: Đường dẫn edit của bài viết, không nên thay đổi thuộc tính này.

Bạn hãy vào đường link này để xem chi tiết hơn vì ở trên mình giải thích có vẻ hơi khó hiểu. Có một giải pháp là bạn vừa cấu hình vừa vào admin để xem kết quả thì sẽ dễ hiểu hơn rất nhiều.

3. Thêm một Post Type mới

Bây giờ chúng ta sử dụng hàm register_post_type để thêm thể loại video nhé.

Tiếp theo bạn nhập nội dung sau vào file custom-post-type.php.

add_action('init', 'create_video_type');

function create_video_type() {
    register_post_type('video', array(
            'label' => '123123',
            'labels' => array(
                'name'          => __('Videos'),
                'singular_name' => __('Video'),
                'add_new_item'  => __('Add New Video'),
                'new_item'      => __('New Video'),
                'add_new'       => __('Add Video'),
                'edit_item'     => __('Edit Video'),
                'search_items'  => __('Search Videos'),
                'all_items'  => __('Videos'),
                // Còn nhiều nữa các bạn tự thêm nhé
            ),
            'public' => true,
            'has_archive' => true,
            'exclude_from_search' => true,
            'capability_type' => array(
                'edit_post'          => 'edit_video', 
                'read_post'          => 'read_video', 
                'delete_post'        => 'delete_video', 
                'edit_posts'         => 'edit_videos', 
                'edit_others_posts'  => 'edit_others_videos', 
                'publish_posts'      => 'publish_videos',       
                'read_private_posts' => 'read_private_videos', 
                'create_posts'       => 'edit_videos', 
            )
            // Còn nhiều nữa ...
        )
    );
}

Bạn đăng nhập vào admin thì sẽ thấy giao diện như sau:

Giao diện cũng không khác gì mấy so với phần 1.

Sau khi chạy đoạn code trên thì chúng ta có thêm thể loại video.

4. Lời kết

Custom Post Type là một chức năng khá quan trọng khi bạn lập trình trên WordPress bởi hầu hết các dự án đều phải tạo ra những Post Type mới. Cũng có bạn nói cái này ít sử dụng bởi các bạn sử dụng FW hoặc những plugin khác thì sự thật không phải như vậy, các FW hoặc các plugin đó cũng phải sư dụng cách này để tạo ra những thể loại đó đấy.

Bạn hãy thay đổi các thuộc tính và vào trang Admin để xem kết quả nó thay đổi như thế nào nhé.

Hãy để lại link bài viết gốc khi chia sẻ bài viết này, mình sẽ report DMCA với những website lấy nội dung mà không để nguồn hoặc copy bài với số lượng lớn.

Nguồn: freetuts.net

Profile photo of adminTheHalfHeart

TheHalfHeart

Có sở thích viết tuts nên đã từng tham gia viết ở một số diễn đàn, đến năm 2014 mới có điều kiện sáng lập ra freetuts.net. Sinh năm 90 và có 1 vợ 2 con, thích ca hát và lập trình.

ĐĂNG BÌNH LUẬN: Đăng câu hỏi trên Group Facebook để được hỗ trợ nhanh nhất.