Відповіді:
Параметр буде переміщений з nid на повний об'єкт вузла до моменту отримання доступу до нього, так що:
$node = \Drupal::routeMatch()->getParameter('node');
if ($node instanceof \Drupal\node\NodeInterface) {
// You can get nid and anything else you need from the node object.
$nid = $node->id();
}
Додаткову інформацію див. У записі змін .
/taxonomy/term/{tid}
?
menu_get_object
?
{}
свого маршруту. Для таксономічних термінів називається параметр taxonomy_term
маршруту, визначення маршруту /taxonomy/term/{taxonomy_term}
. Тут ви можете отримати його , як це, \Drupal::routeMatch()->getParameter('taxonomy_term')
.
якщо ви використовуєте або створюєте користувальницький блок, вам потрібно буде дотримуватися цього коду, щоб отримати поточний ідентифікатор вузла URL-адреси.
// add libraries
use Drupal\Core\Cache\Cache;
// code to get nid
$node = \Drupal::routeMatch()->getParameter('node');
$node->id() // get current node id (current url node id)
// for cache
public function getCacheTags() {
//With this when your node change your block will rebuild
if ($node = \Drupal::routeMatch()->getParameter('node')) {
//if there is node add its cachetag
return Cache::mergeTags(parent::getCacheTags(), array('node:' . $node->id()));
} else {
//Return default tags instead.
return parent::getCacheTags();
}
}
public function getCacheContexts() {
//if you depends on \Drupal::routeMatch()
//you must set context of this block with 'route' context tag.
//Every new route this block will rebuild
return Cache::mergeContexts(parent::getCacheContexts(), array('route'));
}
Зауважте на сторінці попереднього перегляду вузла, наступне не працює:
$node = \Drupal::routeMatch()->getParameter('node');
$nid = $node->id();
Для сторінки попереднього перегляду вузла ви повинні завантажити вузол таким чином:
$node = \Drupal::routeMatch()->getParameter('node_preview');
$nid = $node->id();
Як завантажити об’єкт вузла на сторінку попереднього перегляду вузла?