Easy-to-follow video tutorials help you learn software, creative, and business skills.Become a member

Setting up a custom post type

From: Create an Online Portfolio with WordPress

Video: Setting up a custom post type

Custom post types can be added through plug-ins or they can be hardcoded into the theme you're using. I find the latter to be a far more solid way to go and it also ensures that everything works properly even if your plug-in doesn't. Setting up a basic custom post type is easy and only requires a few simple lines of code in functions.php, or in our case, in the abstraction file, posttypes.php. The project we are working on, Culinary Artistry, requires three custom post types: one for recipes, one for photos, and one for videos.

Setting up a custom post type

Custom post types can be added through plug-ins or they can be hardcoded into the theme you're using. I find the latter to be a far more solid way to go and it also ensures that everything works properly even if your plug-in doesn't. Setting up a basic custom post type is easy and only requires a few simple lines of code in functions.php, or in our case, in the abstraction file, posttypes.php. The project we are working on, Culinary Artistry, requires three custom post types: one for recipes, one for photos, and one for videos.

The code to create these is exactly the same. The only thing that changes is the function names and the names of the post types themselves. Now before we go there, if you look at your Admin panel right now, you'll see that you have this word Hello! at the very top even in the Admin panel. If you remember, this is the same Hello! we added inside the posttypes.php file to make sure it works and this just proves the point that when you add something to the functions file it applies to everything that has to do with your WordPress installation, both on the front-end and the back-end, and that's what we are going to use now.

So the first thing we need to do is of course take out this echo Hello! and then we can start building our first post type. Because building a post type requires exact code, I have created a code-snippet for you, so you can go to the code- snippets file and find here it says In posttypes.php and then it lists the actual function. So if we copy it from Add new post types for Recipes down to the end curly bracket here and paste it into posttypes .php, we have the function that creates the post type Recipes.

I will just explain it to you quickly. At the very top we have a comment that just explains what it is, I always tend to add comments to every new function I make, so that when I come back later I know what's going on. The function itself is here. It's called cooking recipes init and this is the function that creates the actual custom post type. It consists of a set of arguments and then the function register_post_type and then the name of the post type and the arguments. So this post type is called recipes because it's recipes, and the arguments have labeled, recipes, which is the name of the post type itself as it is displayed inside WordPress.

It also has the singular label recipe for singular instances and then it has a bunch of other values. It says public to true because it's supposed to be publicly visible so when people visit your site they can see it. It's publicly_queryable. It shows the UI as you can see the UI when you are logged into WordPress, the UI being where you can add a title, description and all this kind of stuff. The query_var is set to true. This is how you are able to query the content, whether or not you can say I want the information from this post type and I only want the titles.

The rewrite is set to true so that WordPress can rewrite the URL. We will get back to that later. The capability_type is set to post right now. You can also set it to page. This just has to do with how WordPress handles the content. It's not hierarchical right now because I set it to false. There is no need to have it on true unless you want to. And the menu_position is set to null. We will get back to that later too. And finally there is a support variable that tells WordPress what content is supported within the actual individual posts.

We will also get back to that later. The final thing that happens is after this function is built we have this add_action at the top. The add_action actually calls the function into WordPress. Right now it's been called add init, which is when WordPress Admin boots up, and the function called is this cooking_ recipes_init which is the one we just made. If we save this file and go into WordPress Admin, you will see that the Hello! disappears and something else happens as well.

So just reload it and you will see Hello! disappeared and down here at the bottom we now have a new post type, Recipes. If we click on it, you will see it looks just like posts except it says Recipes and you can add a new recipe and in time you will also be able to manage it. When we go in and Add New, you will also see we have Title, Content or Editor, and Discussion. If you go back to our code, you will see here under supports that we have title, editor, and comments.

To add a second custom post type, all we need to do now is simply copy this batch of code and paste it in. Then we will just make some quick changes, we will call this Photos instead, call it cooking_photos and change the actual function, and now we change the label and the singular_label. And Photo and finally down here register_post_type, we will call it photos.

Save it, reload WordPress Admin, and now we have both Recipes and Photos. We will do the same for videos. Copy it into our function, paste it in, change to Videos, and change the actual function, call it cooking_videos, and now we change the label and the singular_label and at the bottom here.

Save, reload WordPress Admin, and we now have three custom post types: Recipes, Photos, and Videos. If you didn't quite follow along here, I created a complete code snippet for you. You can just copy out the entire batch of code here. Under In posttypes.php, you can copy everything from the beginning PHP delimiter all the way till the end PHP delimiter and simple mark all your content in posttype.php, delete it, and then just paste this in instead and you will get the exact same result you just saw that I made.

As you can see, adding basic custom post types to your theme is very easy as long as you keep your code in order and creating new ones is as easy as copying an existing one and just renaming the functions and the post type itself. But we're not quite done here. Though these post types work, they are not very well-refined. That's the next step.

Show transcript

This video is part of

Image for Create an Online Portfolio with WordPress
Create an Online Portfolio with WordPress

40 video lessons · 28398 viewers

Morten Rand-Hendriksen
Author

 
Expand all | Collapse all
  1. 6m 28s
    1. Welcome
      58s
    2. Using the exercise files
      3m 54s
    3. Using the code snippets file
      1m 36s
  2. 8m 31s
    1. What is an online portfolio?
      2m 43s
    2. Tour of the finished project
      3m 15s
    3. Setting up a WordPress development environment
      2m 33s
  3. 16m 10s
    1. Creating site architecture
      5m 1s
    2. Creating a child theme
      6m 7s
    3. Creating an external file to manage functions separately from the theme
      5m 2s
  4. 25m 26s
    1. What is a custom post type?
      2m 14s
    2. Setting up a custom post type
      6m 39s
    3. Adding advanced variables to the custom post type
      3m 35s
    4. Advanced custom post type functionalities
      4m 29s
    5. Changing the menu position of the custom post type
      3m 19s
    6. Adding a custom post type icon
      5m 10s
  5. 22m 8s
    1. What are custom taxonomies?
      3m 34s
    2. Setting up a basic custom taxonomy
      2m 52s
    3. Hooking a custom taxonomy to a post type
      3m 13s
    4. Adding advanced variables to a custom taxonomy
      3m 9s
    5. Using hierarchical and nonhierarchical custom taxonomies
      5m 54s
    6. Using custom taxonomies in admin
      3m 26s
  6. 25m 40s
    1. Populating content into the custom post types
      10m 54s
    2. Uploading videos to YouTube
      2m 22s
    3. Embedding YouTube videos in a custom post type
      4m 23s
    4. Uploading videos to WordPress
      8m 1s
  7. 39m 47s
    1. Creating custom post type templates
      6m 50s
    2. Adding taxonomy info to the custom post type template
      9m 13s
    3. Creating conditional custom taxonomy links
      4m 46s
    4. Handling multiple post type templates: Individual templates
      6m 25s
    5. Handling multiple post type templates: Consolidating everything in one file
      6m 21s
    6. Handling multiple post type templates: Making custom post types the default
      6m 12s
  8. 15m 23s
    1. Creating an index page for a custom post type
      8m 10s
    2. Creating a custom taxonomy index page
      7m 13s
  9. 12m 3s
    1. Creating a custom footer sidebar template
      6m 58s
    2. Displaying a list of links to the latest custom post type posts
      5m 5s
  10. 14m 58s
    1. Creating static pages for the front and the blog
      4m 54s
    2. Populating the menu with new index pages
      4m 52s
    3. Creating a contact page with a contact form
      5m 12s
  11. 5m 55s
    1. Including the abstraction layer in other stock themes
      5m 55s
  12. 1m 22s
    1. Next steps
      1m 22s

Start learning today

Get unlimited access to all courses for just $25/month.

Become a member
Sometimes @lynda teaches me how to use a program and sometimes Lynda.com changes my life forever. @JosefShutter
@lynda lynda.com is an absolute life saver when it comes to learning todays software. Definitely recommend it! #higherlearning @Michael_Caraway
@lynda The best thing online! Your database of courses is great! To the mark and very helpful. Thanks! @ru22more
Got to create something yesterday I never thought I could do. #thanks @lynda @Ngventurella
I really do love @lynda as a learning platform. Never stop learning and developing, it’s probably our greatest gift as a species! @soundslikedavid
@lynda just subscribed to lynda.com all I can say its brilliant join now trust me @ButchSamurai
@lynda is an awesome resource. The membership is priceless if you take advantage of it. @diabetic_techie
One of the best decision I made this year. Buy a 1yr subscription to @lynda @cybercaptive
guys lynda.com (@lynda) is the best. So far I’ve learned Java, principles of OO programming, and now learning about MS project @lucasmitchell
Signed back up to @lynda dot com. I’ve missed it!! Proper geeking out right now! #timetolearn #geek @JayGodbold
Share a link to this course

What are exercise files?

Exercise files are the same files the author uses in the course. Save time by downloading the author's files instead of setting up your own files, and learn by following along with the instructor.

Can I take this course without the exercise files?

Yes! If you decide you would like the exercise files later, you can upgrade to a premium account any time.

Become a member Download sample files See plans and pricing

Please wait... please wait ...
Upgrade to get access to exercise files.

Exercise files video

How to use exercise files.

Learn by watching, listening, and doing, Exercise files are the same files the author uses in the course, so you can download them and follow along Premium memberships include access to all exercise files in the library.


Exercise files

Exercise files video

How to use exercise files.

For additional information on downloading and using exercise files, watch our instructional video or read the instructions in the FAQ.

This course includes free exercise files, so you can practice while you watch the course. To access all the exercise files in our library, become a Premium Member.

Are you sure you want to mark all the videos in this course as unwatched?

This will not affect your course history, your reports, or your certificates of completion for this course.


Mark all as unwatched Cancel

Congratulations

You have completed Create an Online Portfolio with WordPress.

Return to your organization's learning portal to continue training, or close this page.


OK
Become a member to add this course to a playlist

Join today and get unlimited access to the entire library of video courses—and create as many playlists as you like.

Get started

Already a member?

Become a member to like this course.

Join today and get unlimited access to the entire library of video courses.

Get started

Already a member?

Exercise files

Learn by watching, listening, and doing! Exercise files are the same files the author uses in the course, so you can download them and follow along. Exercise files are available with all Premium memberships. Learn more

Get started

Already a Premium member?

Exercise files video

How to use exercise files.

Ask a question

Thanks for contacting us.
You’ll hear from our Customer Service team within 24 hours.

Please enter the text shown below:

The classic layout automatically defaults to the latest Flash Player.

To choose a different player, hold the cursor over your name at the top right of any lynda.com page and choose Site preferencesfrom the dropdown menu.

Continue to classic layout Stay on new layout
Exercise files

Access exercise files from a button right under the course name.

Mark videos as unwatched

Remove icons showing you already watched videos if you want to start over.

Control your viewing experience

Make the video wide, narrow, full-screen, or pop the player out of the page into its own window.

Interactive transcripts

Click on text in the transcript to jump to that spot in the video. As the video plays, the relevant spot in the transcript will be highlighted.

Are you sure you want to delete this note?

No

Your file was successfully uploaded.

Thanks for signing up.

We’ll send you a confirmation email shortly.


Sign up and receive emails about lynda.com and our online training library:

Here’s our privacy policy with more details about how we handle your information.

Keep up with news, tips, and latest courses with emails from lynda.com.

Sign up and receive emails about lynda.com and our online training library:

Here’s our privacy policy with more details about how we handle your information.

   
submit Lightbox submit clicked
Terms and conditions of use

We've updated our terms and conditions (now called terms of service).Go
Review and accept our updated terms of service.