Creating your blog with Builder empowers your editors to build exciting blog articles in an intuitive drag-and-drop UI.
Setup
If you don't have one already, create an account over at builder.io/signup. It's free!
In this example we are also assuming you are a developer and will be connecting this blog to a custom website or app.
Creating a Blog article model
First, we need to make a model for our blog articles. Here's the how-to:
- Go to builder.io/models.
- Make a new model by clicking the + Create Model button and choosing Section.
- Name the model
Blog article
. - Click the Create button.
5. Next, add some fields. Lots of blog posts usually include the following fields:
Name | Type | Notes |
---|---|---|
Title |
| This is the article title when listing articles and for the page |
Handle |
| This is the URL handle; for example, |
Image |
| This is the main image for the blog post—for example, when listing articles—as well as the |
Date |
| This is the date for displaying when this was posted and for filtering by date posted. |
Blurb |
| Optional This is the preview text when listing blog articles, and optionally can be the SEO |
Author |
| Optional Use this to list info about authors. We recommend making a new data model—for example, with fields |
The following video shows how to add each of these fields to the model and specify each type. You can define the options of each field, such as default values or whether the field is required, to meet your particular needs. In practice, you might also want to fill in the Helper Text field so editors know the purpose of each field:
The image below shows a still screenshot of these fields in the Blog article model:
Tip: Consider marking some of those options, such as Title
, Handle
, Image
, and Date
required so the editor must enter those values to publish.
Connecting the model to a site
Now, you can query your Blog Articles using our Javascript SDK, Content API, or GraphQL API.
Displaying an article
Next, let's render an individual article.
Next.js Example
// pages/blog/[handle].jsx
import {
builder,
BuilderComponent,
BuilderContent,
useIsPreviewing,
} from "@builder.io/react";
import React from 'react';
import Head from "next/head";
import DefaultErrorPage from "next/error";
builder.init(YOUR_KEY);
function BlogArticle({ article }) {
const isPreviewing = useIsPreviewing();
if (!article && !isPreviewing) {
return (
<>
<Head>
<meta name="robots" content="noindex" />
</Head>
<DefaultErrorPage statusCode={404} />
</>
);
}
return (
<BuilderContent
content={article}
options={{ includeRefs: true }}
model="blog-article"
>
{(data, loading, fullContent) => (
<React.Fragment>
<Head>
{/* Render meta tags from custom field */}
<title>{data?.title}</title>
<meta name="description" content={data?.blurb} />
<meta name="og:image" content={data?.image} />
</Head>
<div>
<div>{data?.title}</div>
{/* Render the Builder drag/drop'd content */}
<BuilderComponent
name="blog-article"
content={fullContent}
options={{ includeRefs: true }}
/>
</div>
</React.Fragment>
)}
</BuilderContent>
);
}
export async function getStaticProps({ params }) {
const article = await builder
.get("blog-article", {
// Include references, like our `author` ref
options: { includeRefs: true },
query: {
// Get the specific article by handle
"data.handle": params.handle,
},
})
.promise() || null;
return {
props: {
article,
},
revalidate: 5,
};
}
export async function getStaticPaths() {
return {
paths: [],
fallback: true,
};
}
export default BlogArticle;
Tip: For more detailed instructions on integrating Builder with your site, check out Integrating Sections.
Searching for article
Builder.io API supports Mongodb style query of your data, for example to get a list of articles that has specific text in their title or description, you can do
import { builder } from '@builder.io/react';
export const search = (searchString) => builder.getAll('blog-article', {
query: {
'$or': [{
'data.description': {
$regex: `${searchString}`,
$options: 'i'
},
},
{
'data.title': {
$regex: `${searchString}`,
$options: 'i'
},
},
]
}
})
Setting up preview by handle
Once you get the code setup locally, let's connect your local site to the Visual Editor. This will allow for accurate previewing and editing as well as using your custom components directly in the editor.
- Go to Models.
- Open the Blog Article model.
- Click on the code icon,
< >
to the right of the Preview URL field. This opens a code editor with comments giving more context on this feature.
- Use the code below which tells the editor to show the page on the blog/[handle], then save model changes.
return `http://localhost:3000/blog/${content.data.handle || '_'}`
Tip: For more detailed instructions on using a preview URL, check out Editing and Previewing Your Site.
Create a Blog Article
Now you can go to builder.io/content, click + New Entry
and choose Blog Article
. You should now see the drag and drop editor loaded right onto your local site.
You can now create articles with drag-and-drop and publish them when you're ready.
To create a blog article content entry, do this:
- Go to Content where you should see the Blog article model in the list on the left.
- Click the + New button and select Blog article. The recommended fields we added in the first section of the tutorial are in the Options tab, ready for you to fill out.
- Add some content and publish!
When you publish your site updates to production, make sure to update your editing URL to be a production URL, such as https://your-site.com/blog/_
and no longer localhost
so other team members can create blog posts.
And that's it!
We've showed several key features here such as custom models, custom fields, and connecting to your website
If you have any questions, ask in our forum!