In this topic we will cover different way of Navigation used in LWC
Use the navigation service, lightning/navigation
, to navigate to many different page types, like records, list views, and objects.
In the component’s JavaScript class, import the NavigationMixin
function from the lightning/navigation
module.
import { NavigationMixin } from "lightning/navigation";
After importing you have to Apply the “NavigationMixin” function to your component’s base class
export default class MyCustomElement extends NavigationMixin(LightningElement) {}
Instead of a URL, the navigation service uses a PageReference
. A PageReference
is a JavaScript object that describes the page type, its attributes, and the state of the page.
PageReference Property
- type :- Its a String type, To navigate in Lightning Experience, Experience Builder sites, or the Salesforce mobile app, define a
PageReference
object. ThePageReference
type generates a unique URL format and defines attributes that apply to all pages of that type. - attributes :- Its a Object type, Map of name-value pairs that determine the target page. The page type defines the set of possible attribute names and their respective value types.
- state :- Its a Object type, Set of key-value pairs with string keys and string values. These parameters conditionally customize content within a given page. Some page reference types support a standard set of
state
properties.
The navigation service adds two APIs to your component’s class. Since these APIs are methods on the class, invoke them from this
.
▶[NavigationMixin.Navigate](pageReference, [replace])
A component callsthis[NavigationMixin.Navigate]
to navigate to another page in the application.
▶[NavigationMixin.GenerateUrl](pageReference)
A component callsthis[NavigationMixin.GenerateUrl]
to get apromise
that resolves to the resulting URL. The component can use the URL in thehref
attribute of an anchor. It can also use the URL to open a new window using thewindow.open({url})
browser API.
In this article, I have mentioned few Page References that are given below.
standard__namedPage
data:image/s3,"s3://crabby-images/8f047/8f047624cadd272650d66ccb077aca19d9291ecc" alt=""
standard__objectPage
data:image/s3,"s3://crabby-images/cc7d6/cc7d60f4f0957108a62c60ba025b0e9ae0990f51" alt=""
data:image/s3,"s3://crabby-images/4ba70/4ba70e5011cd897f43e4e94c7772ca1c8da8c440" alt=""
standard__navItemPage
data:image/s3,"s3://crabby-images/7a37e/7a37e9ce523b99f63ed39629b5b2cb1069839078" alt=""
standard__recordPage
data:image/s3,"s3://crabby-images/80e6a/80e6a5ac647b906847172df4f813d2f7e329a871" alt=""
data:image/s3,"s3://crabby-images/ee654/ee6548a8353d84c5dc745c92075e6dffed973926" alt=""
standard__recordRelationshipPage
data:image/s3,"s3://crabby-images/25cb4/25cb40d6a6eb000315dee67c1baa3e70c5529095" alt=""
standard__webPage
data:image/s3,"s3://crabby-images/0ec23/0ec237550dbe67539dfc497c62af5b96c9a313db" alt=""
For more information about PageReference you can click here
Demonstration
Navigate to Home Page
data:image/s3,"s3://crabby-images/bd9d4/bd9d43bef0344234c45e9a2bffe8d071065dc431" alt=""
data:image/s3,"s3://crabby-images/238eb/238ebbb98993081f06f15630375af71944168363" alt=""
data:image/s3,"s3://crabby-images/820c3/820c3c76cfe05326e9f02f70373c49ce5f25efca" alt=""
Navigate to Object Page
data:image/s3,"s3://crabby-images/8e32b/8e32bd0d12746605229497b7003e2a09fb0189af" alt=""
data:image/s3,"s3://crabby-images/23bc7/23bc7a9356aa90c6f52c9cdc54c2bee9b7390fae" alt=""
data:image/s3,"s3://crabby-images/18595/1859593b38059dd4425041fe808aea7042401bef" alt=""
Navigate to Object page with default value
To provide a default value, we need to import encodeDefaultFieldValues from ‘lightning/pageReferenceUtils’.
import {encodeDefaultFieldValues} from 'lightning/pageReferenceUtils'
data:image/s3,"s3://crabby-images/29385/29385e326cbe450794ff37196951d63631461db6" alt=""
data:image/s3,"s3://crabby-images/ea6ba/ea6ba63f06cc6eb32f2bae163743ef9c295dd150" alt=""
data:image/s3,"s3://crabby-images/a21f5/a21f5dba84b307206e6cbbb50255c3ea2a246152" alt=""
Navigate to Tab
data:image/s3,"s3://crabby-images/9c85b/9c85b9f75c28cc7f3c1575c18b50008c069a7cc0" alt=""
data:image/s3,"s3://crabby-images/207c2/207c252c1f8bb99141624a734443b7fc235e172f" alt=""
data:image/s3,"s3://crabby-images/5219a/5219a86463c9e716ca765484d78b9e58190ab8f4" alt=""
Navigate to Record Page
data:image/s3,"s3://crabby-images/a5d83/a5d838ff1a6472fcf5a5b604f9b2226036c75ba9" alt=""
data:image/s3,"s3://crabby-images/ef577/ef577b2d5a6c8eb3c4d897aa133b02c4322d25c2" alt=""
data:image/s3,"s3://crabby-images/b3e56/b3e5644570c5bee3bcd33efad3e4703ce03ecf6b" alt=""
Navigate to Record Relationship Page
data:image/s3,"s3://crabby-images/1f77b/1f77bddfdb93039981fcee3061bab9aade6c30e9" alt=""
data:image/s3,"s3://crabby-images/25201/252016487a63fefe46ca564d3033a694a87e2e80" alt=""
data:image/s3,"s3://crabby-images/f18a2/f18a24f0ecf3f7ed07e7411e5082da7e824b7aca" alt=""
Navigate to External Web Page
data:image/s3,"s3://crabby-images/0d42d/0d42d9bacd18fa1f5b314b1a0ecbed13ac0b80d8" alt=""
data:image/s3,"s3://crabby-images/ca5fa/ca5faba23c73b63f9693ef6d4d868363d12a86f7" alt=""
data:image/s3,"s3://crabby-images/f2eae/f2eaeddfad667d5d87dd36ef83aedc40f5b0b84c" alt=""
Navigate to LWC Component
data:image/s3,"s3://crabby-images/330ca/330ca5f622c48f8feea68bf717a7a5de9de2cec5" alt=""
data:image/s3,"s3://crabby-images/bd6e0/bd6e093a557d751d5ffe55c220d35faea6cfffe3" alt=""
data:image/s3,"s3://crabby-images/a6bd4/a6bd4abd1feec3034e3621debd23956b0d766966" alt=""
Get Current Page Reference
data:image/s3,"s3://crabby-images/5a3c7/5a3c73ac204641203071bccbb2c9abb93866d157" alt=""
data:image/s3,"s3://crabby-images/37023/370230cb5d927d53ea903a535fade47e31c6617a" alt=""
data:image/s3,"s3://crabby-images/b9290/b929041dce8c495a66153f1cb4990ba3a4344419" alt=""
Follow me on linkedIn and Twitter for such more related post
Comments
Post a Comment