Newer Version Available
Configure Components for Lightning Experience Record Pages
Record pages are different from app pages in a key way: they have the context of a record. To make your components display content that is based on the current record, use a combination of an interface and an attribute.
- If your component is available for both record pages and any other type of page, implement flexipage:availableForAllPageTypes.
- If your component is designed just for record pages, implement the flexipage:availableForRecordHome interface instead of flexipage:availableForAllPageTypes.
- If your component needs the record ID, also implement the force:hasRecordId interface.
- If your component needs the object’s API name, also implement the force:hasSObjectName interface.
force:hasRecordId
Useful for components invoked in a context associated with a specific record, such as record page components or custom object actions. Add this interface if you want your component to receive the ID of the currently displaying record.
- It adds an attribute named recordId to your
component. This attribute is of type String, and its value is an 18-character
Salesforce record ID, for example: 001xx000003DGSWAA4. If you added it yourself,
the attribute definition would look like
this:
1<aura:attribute name="recordId" type="String" /> - When your component is invoked in a record context in Lightning Experience or Salesforce1, the recordId is set to the ID of the record being viewed.
Don’t expose the recordId attribute to the Lightning App Builder—don’t put it in the component’s design resource. You don’t want admins supplying a record ID.
The record ID is set only when you place the component on a record page, or invoke it as an action from a record page. In all other cases, such as when you create this component programmatically inside another component, the record ID isn’t set, and your component shouldn’t depend on it.
force:hasSObjectName
Useful for record page components. Implement this interface if your component needs to know the API name of the object of the currently displaying record.
1<aura:attribute name="sObjectName" type="String" />The sObjectName attribute is populated only when you place the component on a record page. In all other cases, such as when you create this component programmatically inside another component, sObjectName isn’t populated, and your component shouldn’t depend on it.