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

The route

Inside our module, we will need to create our routing file that will hold all our statically defined routes. The name of this file will be hello_world.routing.yml. By now, I assume that you understand what the deal is with the file naming conventions in a Drupal 8 module. However, in any case, this is another YAML file in which we will need to put the YAML formatted data:

hello_world.hello:
path: '/hello'
defaults:
_controller: '\Drupal\hello_world\Controller\HelloWorldController::helloWorld'
_title: 'Our first route'
requirements:
_permission: 'access content'

This is our first route definition. It starts with the route name (hello_world.hello), followed by all the necessary info about it, underneath, in a YAML-formatted multidimensional array. The standard practice is to have the route name start with the module name it is in, followed by route qualifiers as needed.

So, what does the route definition contain? There can be many options here but, for now, we will stick with the simple ones that serve our purpose.

For more info about all route configuration options, visit the relevant documentation page at  https://www.drupal.org/docs/8/api/routing-system/structure-of-routes. It is a good resource to keep on hand.

First, we have a path key, which indicates the path we want this route to work on. Then, we have a defaults section, which usually contains info relevant to the handlers responsible for delivering something when this route is accessed. In our case, we set the controller and method responsible for delivering the page, as well as its title. Finally, we have a requirements section, which usually has to do with conditions that need to be met for this route to be accessible (or be hit)—things such as permissions and format. In our case, we will require users to have the access content permission, which most visitors will have. Don't worry; we will cover more about access in a later chapter.

That is all we need for our first route definition. Now, we will need to create the Controller that maps to it and can deliver something to the user.

Before we do that, let's look at an example of a very common routing requirement you will most likely have to use really soon. We don't need this for the functionality we're building in this chapter, so I won't include it in the final code. However, it's important that you know how this works.

主站蜘蛛池模板: 新丰县| 湘潭县| 木里| 汉沽区| 邮箱| 马尔康县| 吉首市| 永春县| 阜新| 五指山市| 柏乡县| 饶平县| 太仆寺旗| 玛多县| 天台县| 海丰县| 科技| 安庆市| 柳州市| 防城港市| 平泉县| 湘潭县| 定结县| 襄城县| 江口县| 玉龙| 黎城县| 普宁市| 桂东县| 依安县| 三河市| 凤城市| 弋阳县| 柘荣县| 永安市| 清徐县| 津南区| 山丹县| 泸西县| 涟源市| 淮北市|