Cookies setting

Cookies help us enhance your experience on our site by storing information about your preferences and interactions. You can customize your cookie settings by choosing which cookies to allow. Please note that disabling certain cookies might impact the functionality and features of our services, such as personalized content and suggestions. Cookie Policy

Cookie Policy
Essential cookies

These cookies are strictly necessary for the site to work and may not be disabled.

Information
Always enabled
Advertising cookies

Advertising cookies deliver ads relevant to your interests, limit ad frequency, and measure ad effectiveness.

Information
Analytics cookies

Analytics cookies collect information and report website usage statistics without personally identifying individual visitors to Google.

Information
mageplaza.com

How to Add a New CMS Page in Magento 2

Vinh Jacker | 06-22-2016

Add a New CMS Page

Adding a New CMS (Content Management System) Page is an easy action you can do with Magento 2 Configuration. All pages, from ‘About us’ page, ‘Contact us’ page, to other landing pages, are CMS pages. Thanks to these CMS Pages, owners can show dynamic content to shoppers and manage multiple contents at the same time. From the backend, the new page is created by text, images, blocks of content, variables, and frontend. All of them are designed friendly for both search engines that crawl the metadata of the page and people who access your page.

Using CMS Pages strategically can reduce the abandonment rate by 66% as well as increase the conversion rate by 30%. Ignore the back and forth that are the redundant motions when standing on your site. If you are facing the problem with filtering products in navigation, this will help. The below are six steps you need to walk through to add a new CMS page successfully. After that, you can find instructions on how to assign a Home Page in Magento 2.

Table of Contents

6 Steps to Add a New CMS Page in Magento 2

Step 1: Add a New Page

  • On the Admin Panel, Content > Elements > Pages.
  • Click on Add New Page.

How to Add a New CMS Page Page Information

  • Under the Page Information section:
    • Fill out the Page Title, the meta data that shows in the title bar and tab of the browser.
    • Fill out a URL Key for the page, added to the base URL for the new online address of the page.

    Remember to insert lowercase characters and hyphens without spaces.

    • In the Store View list, choose the store view which the page is displayed on.
    • Set Disable if it is not ready to go live, but don’t forget to come back and enable the page status to make it available.
    • Click on Save and Continue Edit.

Step 2: Choose the Page Layout

  • On the left panel, tap the Design tab.
  • In the Layout field, choose one of the options from the dropdown list of the page layout.
    • 1 column
    • 2 columns with left bar
    • 2 columns with right bar
    • 3 columns

How to Add a New CMS Page Page Layout

  • Scroll down to customize the page design. On the Custom Design section, you can change theme, layout, and style within exact time period like holiday or sales.

How to Add a New CMS Page Custom Design

Step 3: Enter the Content

  • On the left panel, tap the Content tab.
  • In the Content Heading field, enter the main heading at the top of the page.
  • Click on the Show/Hide Editor button to edit the text with the WYSIWYG editor.

How to Add a New CMS Page Page Content

  • Hit the Save and Continue Edit

Step 4: Fill out the Meta Data

  • On the left panel, tap the Meta Data tab.
  • Enter the Keywords and Description for the CMS page, that is necessary for SEO.
  • Hit the Save and Continue Edit.

Step 5: Preview the Page

To ensure that all settings are perfect as well as you want to check the formatting, on the upper-right corner, click on Preview link.

Step 6: Generate the Page

  • Return to Page Information and set Status to Enabled.
  • Hit the Save page.

That is all for adding a new page, and now it is ready to be included in your store navigation, or link to other pages, even you can also apply it for your new home page. You can insert products into the homepage here.

Assign a Home Page in Magento 2

You can assign any page as a Home Page according to the following guide:

  • Finish all steps to create a new page.
  • On the Admin Panel, Stores > Settings > Configuration.
  • On the left panel, under General, select Web.
  • Open the Default Pages section,
    • Set CMS Page as Home Page in the CMS Page field.
    • Save Config to activate the settings.
  • Click on the Cache Management link in the system message to flush your cache.

How to Add a New CMS Page Assign a Home Page

The bottom line

Magento 2 Add a new CMS Page is a wonderful feature for any online store, because you can save time by using an user-friendly interface, build your website friendly with SEO, as well as update and manage contents easily. We also have other posts related to CMS pages and blocks that you may want to check out below. Please write questions in the box below if any and we will reply to you soon.

Related Topics

The next step involves customizing your theme’s XML file to add your own code to specific sections of the template. You can achieve this by editing your theme’s layout XML file. However, it is recommended to create a small custom code with an extension to keep your theme files intact. This approach ensures compatibility with theme upgrades and support in the future.

To begin, define a Namespace as “Mage” and ModuleName as “NavigationLink” for your extension. Create a file named “default.xml” in the Magento 2 root at the following location:


Insert the following code into the created file:

```<?xml version="1.0"?>
<page xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:View/Layout/etc/page_configuration.xsd">
<body>
<referenceContainer name="catalog.topnav">
<block class="Magento\Framework\View\Element\Html\Link\Current" name="navigationlink">
<block class="Mage\NavigationLink\Block\Links\Link" name="newpage" after='-' />
</referenceContainer>
</body>```

Next, create a file named "Link.php" at the following location from the Magento 2 root:

```app/Mage/NavigationLink/Block/Links/Link.php```

Insert the following code into the created file, replacing 'cms_page_url_key' with your page URL Key ('new-page') and the page link name ('Link_Name') with 'New Page':

```<?php
namespace Mage\NavigationLink\Block\Links;

class Link extends \Magento\Framework\View\Element\Html\Link {
  public function __construct(
    \Magento\Framework\View\Element\Template\Context $context,
    array $data = []
  ) {
    parent::__construct($context, $data);
  }

  public function getHref() {
    $page_url = 'cms_page_url_key';
    return $this->getUrl($page_url);
  }

  public function getLabel() {
    return 'Link_Name';
  }
}
?>```

Save both files, clear the cache, and activate the extension with the following commands in the command line with SSH access to your Magento 2 server in the Document Root directory:

```php bin/magento setup:upgrade
php bin/magento static:content:deploy```

After both commands have successfully completed, open your website homepage to verify that the link now appears in the Navigation Menu. If you require further customization for your Magento 2 web store, feel free to contact our Magento 2 developers.

## Create custom cms page using Patch Data in Magento 2 {#create-custom-cms}
Generate a Patch file within your module named **CustomCmsPage.php** at the specified path: **Vendor/Module/Setup/Patch/Data/CustomCmsPage.php**.

```<?php
namespace Vendor\Module\Setup\Patch\Data;

use Magento\Framework\Setup\Patch\DataPatchInterface;
use Magento\Framework\Setup\Patch\PatchVersionInterface;
use Magento\Framework\Setup\ModuleDataSetupInterface;
use Magento\Cms\Model\PageFactory;

class CustomCmsPage implements DataPatchInterface, PatchVersionInterface
{
    /**
     * @var ModuleDataSetupInterface
     */
    private $_moduleDataSetup;

    /**
     * @var PageFactory
     */
    private $_pageFactory;

    /**
     * @param ModuleDataSetupInterface $moduleDataSetup
     * @param PageFactory $pageFactory
     */
    public function __construct(
        ModuleDataSetupInterface $moduleDataSetup,
        PageFactory $pageFactory
    ) {
        $this->_moduleDataSetup = $moduleDataSetup;
        $this->_pageFactory = $pageFactory;
    }

    /**
     * {@inheritdoc}
     */
    public function apply()
    {
        $this->_moduleDataSetup->startSetup();

        /* Logic to Save CMS Page */
        $page = $this->_pageFactory->create();
        $page->setTitle('Create CMS page Using Patch')
            ->setIdentifier('custom-cms-page')
            ->setIsActive(true)
            ->setPageLayout('1column')
            ->setStores([0]) // Set store IDs where the page should be available
            ->setContent('Your custom page content goes here…')
            ->save();

        $this->_moduleDataSetup->endSetup();
    }

    /**
     * {@inheritdoc}
     */
    public static function getDependencies()
    {
        return [];
    }

    /**
     * {@inheritdoc}
     */
    public static function getVersion()
    {
        return '2.0.0';
    }

    /**
     * {@inheritdoc}
     */
    public function getAliases()
    {
        return [];
    }
}
?> 

The script defines a Patch class named CustomCmsPage, implementing the DataPatchInterface and PatchVersionInterface. The apply method contains the logic to create a custom CMS page. Other methods specify patch dependencies, version, and aliases.

Replace ‘Your custom page content goes here…’ with the desired content for your custom CMS page. After running the necessary commands to apply the patch, you should be able to locate your custom CMS page in the storefront.

The bottom line

Magento 2 Add a new CMS Page is a wonderful feature for any online store, because you can save time by using an user-friendly interface, build your website friendly with SEO, as well as update and manage contents easily. We also have other posts related to CMS pages and blocks that you may want to check out below. Please write questions in the box below if any and we will reply to you soon.

x
    Jacker

    With over a decade of experience crafting innovative tech solutions for ecommerce businesses built on Magento, Jacker is the mastermind behind our secure and well-functioned extensions. With his expertise in building user-friendly interfaces and robust back-end systems, Mageplaza was able to deliver exceptional Magento solutions and services for over 122K+ customers around the world.



    Related Post

    Website Support
    & Maintenance Services

    Make sure your store is not only in good shape but also thriving with a professional team yet at an affordable price.

    Get Started
    mageplaza services