You need to sign in to do that
Don't have an account?
Michael Kolodner 13
How the heck do I use force:hasRecordID?
I'm trying to build a Lightning Component that I think should be very very simple. I understand that force:hasRecordID should allow a component that's on a Lightning Record Page to know the ID of the record being displayed. I, therefore, would like to take that ability to make a simple component that would show that record ID. (And before you ask, "Why not do it as a formula field?" The answer is that to do that I'd have to build a formula field on every object, whereas this component would be object agnostic. Plus it's a chance for me to learn a little about components...) I thought I could just use the string {!v.recordID}, but clearly I have to take some action to actually get the ID and put it into a variable. I don't know Javascript, so I'm stumped. But I know enough to know that someone who actually knew what they were doing could probably thew this together in seconds.
As I understand I, I think I should need only two things:
1. The component (.cmp)
The code I've got so far is:
2. The controller (.js)
The code I've got for that so far is below. But I've been trying all sorts of things based on Googling and looking on Trailheads and the like, so this part could be way off:
Right now when I put the component on a page it just displays the text, but the string {!v.recordID} is replaced with the default text (or, when I didn't have that, just with nothing).
Help, please?
As I understand I, I think I should need only two things:
1. The component (.cmp)
The code I've got so far is:
<aura:component implements="flexipage:availableForRecordHome,force:hasRecordId" access="global" >
<aura:attribute name="recordID" type="String" default="ID hasn't been set yet!"/>
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
<b>This is recordID {!v.recordID} </b>
</aura:component>
<aura:attribute name="recordID" type="String" default="ID hasn't been set yet!"/>
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
<b>This is recordID {!v.recordID} </b>
</aura:component>
2. The controller (.js)
The code I've got for that so far is below. But I've been trying all sorts of things based on Googling and looking on Trailheads and the like, so this part could be way off:
({
doInit : function(cmp) {
var action = cmp.get("v.recordId");
action.setCallback(this,function(response){
var state = response.getState();
if(state === "SUCCESS"){
cmp.set("v.recordID", response.getReturnValue());
}
});
$A.enqueueAction(action);
}
})
doInit : function(cmp) {
var action = cmp.get("v.recordId");
action.setCallback(this,function(response){
var state = response.getState();
if(state === "SUCCESS"){
cmp.set("v.recordID", response.getReturnValue());
}
});
$A.enqueueAction(action);
}
})
Right now when I put the component on a page it just displays the text, but the string {!v.recordID} is replaced with the default text (or, when I didn't have that, just with nothing).
Help, please?
The toast is just a nice message in Lex.
Regards