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

  • concrete5 Cookbook
  • David Strack
  • 350字
  • 2021-08-13 16:15:55

Getting a page type by its handle

As mentioned in the chapter introduction, page types also have human readable handles, which offer a convenient way of loading page types without knowing their numerical IDs. Handles are always alphanumerical strings with underscores between words, and do not contain any file extensions such as .php. For example, the handle for a page type called "Left Sidebar" would most likely be left_sidebar, but concrete5 lets users specify any alphanumeric string for a handle, so it's possible that the handle for Left Sidebar would also just be left.

You can find the handles of page types by visiting the Page Types area of the concrete5 dashboard, located at /dashboard/pages/types/ on your concrete5 website.

Getting ready

In this recipe, we will be loading a page type with the handle of left_sidebar. Please make sure that page type exists in your concrete5 installation, otherwise you can add a new page type with that handle, or adapt the recipe to work for your situation.

How to do it...

Here's how we would load the page type with a handle of left_sidebar. This is similar to loading a page by its path. The steps are as follows:

  1. Open /config/site_post.php in your preferred code editor.
  2. Declare the handle of the page type that you wish to load.
    $handle = 'left_sidebar';
  3. Load the page type using the handle that we just defined.
    $pageType = CollectionType::getByHandle($handle);
  4. You can verify that you have loaded the page type by dumping the $pageType variable.
    my_debug($pageType);

How it works...

A simple database query is performed, which will return a CollectionType object if it is successful.

There's more...

Just like the warning for loading pages by their paths, you will want to exercise the same good judgment when loading page types by their handles. Since these handles are just strings that can be edited through the concrete5 interface, you will need to make sure that you aren't writing code that could break if one of the site editors changes the handle of a page type.

See also

  • The Getting a page type by its ID recipe
主站蜘蛛池模板: 博罗县| 济源市| 琼结县| 阿瓦提县| 呈贡县| 陵水| 仪陇县| 北宁市| 岗巴县| 五峰| 纳雍县| 金坛市| 林州市| 思茅市| 新闻| 云霄县| 南丹县| 科技| 吉林市| 东阳市| 柯坪县| 望城县| 大姚县| 都兰县| 白沙| 成都市| 内黄县| 将乐县| 綦江县| 卢氏县| 荆门市| 泌阳县| 大丰市| 蓝田县| 洞口县| 聂拉木县| 浦北县| 尤溪县| 景宁| 南阳市| 疏勒县|