官术网_书友最值得收藏!

Adding a block to a page

Users can use the intuitive concrete5 interface to add blocks to the various areas of pages on the website. You can also programmatically add blocks to pages using the concrete5 API.

Getting ready

The code in this chapter can be run anywhere that you would like to create a block. To keep things simple, we are going to use the /config/site_post.php file to run some arbitrary code.

This example assumes that a page with a path of /about exists on your concrete5 site. Feel free to create that page, or adapt this recipe to suit your needs. Also, this recipe assumes that /about has a content area called content. Again, adapt according to your own website's configuration.

We will be using the block that was created at the beginning of this chapter.

How to do it...

The steps for adding a block to a page are as follows:

  1. Open /config/site_post.php in your code editor.
  2. Load the page that you would like to add a block to:
    $page = Page::getByPath('/about');
  3. Load the block by its handle:
    $block = BlockType::getByHandle('hello_world');
  4. Define the data that will be sent to the block:
    $data = array(
      'title' => 'An Exciting Title',
      'content' => 'This is the content!'
    );
  5. Add the block to the page's content area:
     $page->addBlock($block, 'content', $data);

How it works...

First you need to get the target page. In this recipe, we get it by its path, but you can use this function on any Page object. Next, we need to load the block type that we are adding. In this case, we are using the one that was created earlier in the chapter. The block type handle is the same as the directory name for the block.

We are using the $data variable to pass in the block's configuration options. If there are no options, you will need to pass in an empty array, as concrete5 does not allow that parameter to be blank. Finally, you will need to know the name of the content area; in this case, the content area is called "content".

See also

  • The Creating a custom block type recipe
  • The Loading a block type by its handle recipe
  • The Getting a page by its path recipe in Chapter 1, Pages and Page Types
主站蜘蛛池模板: 水城县| 贵阳市| 宁陵县| 嘉鱼县| 柳林县| 工布江达县| 修文县| 伊宁县| 玉田县| 扎赉特旗| 双峰县| 浪卡子县| 攀枝花市| 台湾省| 东宁县| 孟津县| 正阳县| 岱山县| 成安县| 岐山县| 米易县| 嘉荫县| 梓潼县| 宜春市| 土默特左旗| 临湘市| 石台县| 平和县| 亚东县| 江西省| 怀远县| 津市市| 广南县| 孝感市| 五家渠市| 从化市| 秦安县| 乌海市| 平利县| 佛冈县| 台南市|