function hook_entity_view_alter

Alter the results of ENTITY_view().

This hook is called after the content has been assembled in a structured array and may be used for doing processing which requires that the complete entity content structure has been built.

If a module wishes to act on the rendered HTML of the entity rather than the structured content array, it may use this hook to add a #post_render callback. Alternatively, it could also implement hook_preprocess_ENTITY(). See drupal_render() and theme() for details.

Parameters

$build: A renderable array representing the entity content.

$type: The type of entity being rendered (i.e. node, user, comment).

See also

hook_entity_view()

hook_comment_view_alter()

hook_node_view_alter()

hook_taxonomy_term_view_alter()

hook_user_view_alter()

Related topics

3 functions implement hook_entity_view_alter()

Note: the procedural functions in this list are found by pattern matching, so the list may include some functions that are not actually implementations of this hook.

FieldLayoutHooks::entityViewAlter in core/modules/field_layout/src/Hook/FieldLayoutHooks.php
Implements hook_entity_view_alter().
LayoutBuilderHooks::entityViewAlter in core/modules/layout_builder/src/Hook/LayoutBuilderHooks.php
Implements hook_entity_view_alter().
MediaTestEmbedHooks::entityViewAlter in core/modules/media/tests/modules/media_test_embed/src/Hook/MediaTestEmbedHooks.php
Implements hook_entity_view_alter().

File

modules/system/system.api.php, line 459

Code

function hook_entity_view_alter(&$build, $type) {
  if ($build['#view_mode'] == 'full' && isset($build['an_additional_field'])) {
    // Change its weight.
    $build['an_additional_field']['#weight'] = -10;
    // Add a #post_render callback to act on the rendered HTML of the entity.
    $build['#post_render'][] = 'my_module_node_post_render';
  }
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.