Finding the home node in Umbraco

In almost all Umbraco sites you build, you will need to access values stored in the home page. It's fine if you are on the home page already, as you can just use Current Page. But sometimes, you may be on a different page in the site and need to access the Home Page from there. This post shows you how to find the home page (root node) and It shows you how to do it from inside a View or in a Controller.

Please note: This code assumes you are working from a page which is a child or descendant of the home page. Thanks to Matt Brailsford's comment, I've updated the code to make it even simpler.

The highlighted word below is the document type alias for the home document.

In a View

@inherits Umbraco.Web.Mvc.UmbracoTemplatePage
@{     IPublishedContent homePage = Model.Content.AncestorOrSelf("Home"); }

In a Controller

Add these references at the top of the controller

using Umbraco.Web;
using Umbraco.Core.Models;
using System.Linq;

Now you can use this line in one of your methods.

IPublishedContent homePage = CurrentPage.AncestorOrSelf("Home");

That was easy

That's it. Now you know how to do it.

Don't forget to bookmark this page for when you need it later.

Please leave a comment if you have any other requests.

Paul Seal

Umbraco MVP and .NET Web Developer from Derby (UK) who specialises in building Content Management System (CMS) websites using MVC with Umbraco as a framework. Paul is passionate about web development and programming as a whole. Apart from when he's with his wife and son, if he's not writing code, he's thinking about it or listening to a podcast about it.

Proudly sponsored by

Moriyama

  • Moriyama build, support and deploy Umbraco, Azure and ASP.NET websites and applications.
AppVeyor

  • CI/CD service for Windows, Linux and macOS
  • Build, test, deploy your apps faster, on any platform.
stkrs

  • Custom stickers for startups, artists and brands.
  • Bespoke easy-apply, removable, custom brand stickers printed in the UK.
elmah.io

  • elmah.io is the easy error logging and uptime monitoring service for .NET.
  • Take back control of your errors with support for all .NET web and logging frameworks.
uSync Complete

  • uSync.Complete gives you all the uSync packages, allowing you to completely control how your Umbraco settings, content and media is stored, transferred and managed across all your Umbraco Installations.