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;
}