1 node.api.php hook_view(Node $node, $view_mode)

Display a node.

This is a node-type-specific hook, which is invoked only for the node type being affected. See Node API hooks for more information.

Use hook_node_view() to respond to node view of all node types.

This hook is invoked during node viewing after the node is fully loaded, so that the node type module can define a custom method for display, or add to the default display.

Parameters

Node $node: The node to be displayed, as returned by node_load().

$view_mode: Display mode, e.g. 'full', 'teaser', ...

Return value

The passed $node parameter should be modified as necessary and returned so: it can be properly presented. Nodes are prepared for display by assembling a structured array, formatted as in the Form API, in $node->content. As with Form API arrays, the #weight property can be used to control the relative positions of added elements. After this hook is invoked, node_view() calls field_attach_view() to add field views to $node->content, and then invokes hook_node_view() and hook_node_view_alter(), so if you want to affect the final view of the node, you might consider implementing one of these hooks instead.

Related topics

File

core/modules/node/node.api.php, line 1240
Hooks provided by the Node module.

Code

function hook_view(Node $node, $view_mode) {
  if ($view_mode == 'full' && node_is_page($node)) {
    $breadcrumb = array();
    $breadcrumb[] = l(t('Home'), NULL);
    $breadcrumb[] = l(t('Example'), 'example');
    $breadcrumb[] = l($node->field1, 'example/' . $node->field1);
    backdrop_set_breadcrumb($breadcrumb);
  }

  $node->content['myfield'] = array(
    '#markup' => theme('my_module_myfield', $node->myfield),
    '#weight' => 1,
  );

  return $node;
}