สอนสร้าง Plugin WordPress (17) : ตัวอย่างการสร้าง Custom Fields เเละการใช้ wp editor

แชร์ ความรู้สำหรับพัฒนา plugin ของ Wordpress

Moderator: mindphp, ผู้ดูแลกระดาน

ภาพประจำตัวสมาชิก
thatsawan
PHP VIP Members
PHP VIP Members
โพสต์: 10320
ลงทะเบียนเมื่อ: 31/03/2014 10:02 am
ติดต่อ:

สอนสร้าง Plugin WordPress (17) : ตัวอย่างการสร้าง Custom Fields เเละการใช้ wp editor

โพสต์โดย thatsawan » 25/10/2016 12:02 pm

Custom Fields
    การสร้างฟิลด์ใน Post type ต่างๆ เพื่อให้สามารถเก็บค่าต่างๆ เป็นการเพิ่มความสามารถให้กับ WordPress

ตัวอย่างการใช้งาน
ส่วนเเรกเป็นส่วนที่เพิ่ม Post type (ศึกษาได้ในบทก่อนหน้านี้)

โค้ด: เลือกทั้งหมด


add_action
( 'init', 'codex_book_init' );

/**
 * Register a book post type.
 *
 * @link http://codex.wordpress.org/Function_Reference/register_post_type
 */
function codex_book_init() {
  $labels = array(
    'name'               => _x( 'Books', 'post type general name', 'your-plugin-textdomain' ),
    'singular_name'      => _x( 'Book', 'post type singular name', 'your-plugin-textdomain' ),
    'menu_name'          => _x( 'Books', 'admin menu', 'your-plugin-textdomain' ),
    'name_admin_bar'     => _x( 'Book', 'add new on admin bar', 'your-plugin-textdomain' ),
    'add_new'            => _x( 'Add News Demo', 'book', 'your-plugin-textdomain' ),
    'add_new_item'       => __( 'Add New Book', 'your-plugin-textdomain' ),
    'new_item'           => __( 'New Book', 'your-plugin-textdomain' ),
    'edit_item'          => __( 'Edit Book', 'your-plugin-textdomain' ),
    'view_item'          => __( 'View Book', 'your-plugin-textdomain' ),
    'all_items'          => __( 'All Books', 'your-plugin-textdomain' ),
    'search_items'       => __( 'Search Books', 'your-plugin-textdomain' ),
    'parent_item_colon'  => __( 'Parent Books:', 'your-plugin-textdomain' ),
    'not_found'          => __( 'No books found.', 'your-plugin-textdomain' ),
    'not_found_in_trash' => __( 'No books found in Trash.', 'your-plugin-textdomain' )
  );

  $args = array(
    'labels'             => $labels,
    'description'        => __( 'Description.', 'your-plugin-textdomain' ),
    'public'             => true,
    'publicly_queryable' => true,
    'show_ui'            => true,
    'show_in_menu'       => true,
    'show_in_nav_menus' => true,
    'query_var'          => true,
    'rewrite'            => array( 'slug' => 'book' ),
    'capability_type'    => 'post',
    'has_archive'        => true,
    'hierarchical'       => false,
    'menu_position'      => null,
    'supports'           => array( 
               
'title',
               // 'editor', 
               // 'author', 
               // 'thumbnail',   
               // 'excerpt',
               // 'comments' 
     )
  );

  register_post_type( 'book', $args );
}



ส่วนที่ 2 เป็นส่วนที่จะเพิ่ม Custom Fields

โค้ด: เลือกทั้งหมด

function custom_meta_box_markup()
{
 

    echo 
'<label for="my_meta_box_text">Text Label</label>
    <input type="text" name="my_meta_box_text" id="my_meta_box_text" />'
;

}

function add_custom_meta_box()
{
    add_meta_box("demo-meta-box", "Custom Meta Box", "custom_meta_box_markup", "book", "normal", "high", null);
}

add_action("add_meta_boxes", "add_custom_meta_box"); 


ผลที่ได้
รูปภาพ


ตัวอย่างการใช้งาน wp_editor()

โค้ด: เลือกทั้งหมด

function custom_meta_box_markup()
{
 

    echo 
'<label for="my_meta_box_text">Text Label</label>
    <input type="text" name="my_meta_box_text" id="my_meta_box_text" />'
;

    $content = get_post_meta($post->ID,'custom_fields',true);
    $editor_id = 'mycustomeditor';
    $setting = array(
          'textarea_rows' => 8, 
          
'media_buttons' => true, // show button add media

      );
    wp_editor( $content, $editor_id,$setting );
}

function add_custom_meta_box()
{
    add_meta_box("demo-meta-box", "Custom Meta Box", "custom_meta_box_markup", "book", "normal", "high", null);
}

add_action("add_meta_boxes", "add_custom_meta_box");
 

ผลที่ได้
รูปภาพ


ศึกษาเพิ่มเติมที่นี่
https://codex.wordpress.org

ภาพประจำตัวสมาชิก
mindphp
ผู้ดูแลระบบ MindPHP
ผู้ดูแลระบบ MindPHP
โพสต์: 17180
ลงทะเบียนเมื่อ: 22/09/2008 6:18 pm
ติดต่อ:

Re: สอนสร้าง Plugin WordPress (17) : ตัวอย่างการสร้าง Custom Fields เเละการใช้ wp editor

โพสต์โดย mindphp » 25/10/2016 9:45 pm

รวมกระทู้ บทความสอนสร้าง Plugin WordPress
viewtopic.php?f=225&t=36079
ติดตาม VDO: http://www.youtube.com/c/MindphpVideoman
ติดตาม FB: https://www.facebook.com/pages/MindphpC ... 9517401606
หมวดแชร์ความรู้: viewforum.php?f=29
รับอบรม และพัฒนาระบบ: viewtopic.php?f=6&t=2042


  • Similar Topics
    ตอบกลับ
    แสดง
    โพสต์ล่าสุด

ย้อนกลับไปยัง

ผู้ใช้งานขณะนี้

กำลังดูบอร์ดนี้: 3 และ บุคคลทั่วไป 0 ท่าน