То, что вы делаете до сих пор, в основном правильно (клавиша «title» требуется для каждого элемента, поэтому обязательно включите ее). Так как page callback
направлено на mymodule_landing()
, содержимое, возвращаемое этой функцией, будет отображаться как ваше содержимое на странице.
Чтобы создать больше страниц (например, step2, step99 и т. Д.), Вы должны продолжить создавать дополнительные пути в mymodule_menu()
, например:
$items['mymodule/step2'] = array(
'title' => 'Step 2', // Required
'page callback' => 'mymodule_step2',
'access arguments' => array('access content'),
'type' => MENU_NORMAL_ITEM,
);
И так далее ... Вы могли бы использовать один и тот же обратный вызов страницы mymodule_landing()
и просто передавать "аргументы страницы", или каждый из них может иметь свой собственный обратный вызов страницы.
Чтобы поместить вашу функцию mymodule_landing()
в отдельный файл, вы можете использовать клавиши file и path * (см. Ниже)
$items['mymodule/landingpage'] = array(
'title' => 'Landing Page', // Required
'page callback' => 'mymodule_landing',
'access arguments' => array('access content'),
'type' => MENU_NORMAL_ITEM,
'file' => 'mymodule.pages.inc',
'file path' => drupal_get_path('module', 'mymodule'),
);
Вы должны поместить эти файлы в каталог вашего модуля (или в подкаталог внутри каталога модуля и указать правильный путь к файлу ) и иметь доступ к каждой странице в mysite.com/mymodule/landingpage
, mysite.com/mymodule/step2
и т. Д.
Рекомендации по включению файлов обработчика страниц (подробнее на http://drupal.org/node/146172):
Разработчики модулей могут по своему усмотрению разделять обработчики страниц для своих модулей. Тем не менее, рекомендуется следующее руководство и стандарты:
- Любой модуль, имеющий более ~ 50 строк кода для функций обработчика страниц (включая функции обработки форм, если применимо), должен разбивать их на отдельный файл. Это уменьшает накладные расходы на PHP при загрузке модулей и, следовательно, ускоряет каждый запрос на сайте.
- Включаемые файлы страниц должны быть названы в форме modulename.key.inc, где «modulename» - это имя модуля, а «ключ» - это однословный описательный термин для типов обработчиков страниц, которые он включает.
- Для большинства модулей достаточно разбить обработчики страниц на два файла - example.admin.inc (для страниц только для администратора) и example.pages.inc (для страниц, доступных пользователям без прав администратора), и является достаточным рекомендуемая практика. Если в модуле нет страниц без прав администратора, у него должен быть только один файл example.admin.inc. Если у модуля нет страниц, предназначенных только для администратора, у него должен быть только один файл example.pages.inc.
- Модули, которые имеют большое количество обработчиков страниц, могут разделить обработчики страниц еще дальше. Если это так, каждый файл должен быть логически сгруппирован по функциям (например, страницы администратора, связанные с тематикой, страницы администратора, связанные с ведением журнала, другие страницы администратора и страницы, доступные для пользователя) и четко помечены. Помните, что разделение обработчиков страниц модуля слишком далеко усложняет обслуживание, и загружается только один включаемый файл обработчика страниц, независимо от того, насколько тонко разделены функции обработчика.
Добавлено только для справки: Документация hook_menu ()
Вам также может помочь page_example.module .