Create Quick Launch Link in SharePoint using CSOM

The example in this topic show how to use CSOM to Create Quick Launch Link in SharePoint

  • using Microsoft.SharePoint.Client;
  • using System.Linq;
  •  
  • using (ClientContext clientContext = new ClientContext("http://MyServer/sites/MySiteCollection"))
  • {
  • NavigationNodeCollection quickLaunchCollection = null;
  •  
  • // Option 1: This will get quick launch collection from parent web
  • // This option will work only if the method is running from sub-site otherwise parent ID will be Null
  • clientcontext.Load(clientcontext.Web.ParentWeb, p => p.Id);
  • clientcontext.ExecuteQuery();
  • quickLaunchCollection = clientcontext.Site.OpenWebById(clientcontext.Web.ParentWeb.Id).Navigation.QuickLaunch;
  •  
  • // Option 2: This will get quick launch collection from current site
  • quickLaunchCollection = clientcontext.Web.Navigation.QuickLaunch;
  • clientcontext.Load(clientcontext.Web);
  • clientcontext.Load(quickLaunchCollection);
  • clientcontext.ExecuteQuery();
  •  
  • NavigationNodeCreationInformation navigationNodeCreationInformation = new NavigationNodeCreationInformation();
  • navigationNodeCreationInformation.Title = "New navigation";
  • navigationNodeCreationInformation.Url = "New Navigation URL";
  •  
  • // Option 1: This will add the new node at the last position in Node collection
  • // If this is not defined(not set to true), the node will be created at the first position else the node will be created at the last position
  • navigationNodeCreationInformation.AsLastNode = true;
  •  
  • // Option 2: Using Previous node.
  • NavigationNode node = quickLaunchCollection.FirstOrDefault();
  • clientcontext.Load(node.Children);
  • clientcontext.ExecuteQuery();
  •  
  • // Here "Previous navigation" will act as a previous node and the new node will be created after that
  • NavigationNode prevnode = node.Children.Where(Node => Node.Title == "Previous navigation").FirstOrDefault();
  • navigationNodeCreationInformation.PreviousNode = prevnode;
  •  
  • //// Adds the new navigation node to the collection.
  • node.Children.Add(navigationNodeCreationInformation);
  •  
  • clientcontext.Load(quickLaunchCollection);
  • clientcontext.ExecuteQuery();
  • }

Thank you for reading this article. This code was tested in SharePoint 2013


© 2019 Code SharePoint