继续解锁:
data:image/s3,"s3://crabby-images/cca25/cca25dd1e0399ceeb56bae189581e02363c2b8b1" alt=""
https://trailhead.salesforce.com/en/content/learn/superbadges/superbadge_lcf
Lightning Data Service Basics for Aura Components
https://trailhead.salesforce.com/content/learn/modules/lightning_data_service
Get Started with Lightning Data Service for Aura Components
data:image/s3,"s3://crabby-images/9d7bd/9d7bd0a4d66b90d8dfeecdacc69cd5b258c51156" alt=""
data:image/s3,"s3://crabby-images/b7915/b7915b4df1d6531fb3f3534471fb652606a17760" alt=""
Manipulate Records with force:recordData
data:image/s3,"s3://crabby-images/d4fe3/d4fe3ac9703880fb4fdb448245ce6dbbc250c4b5" alt=""
data:image/s3,"s3://crabby-images/e45c9/e45c9104adca3f51d009a5b40a398b83ef51c6e5" alt=""
accDisplay.cmp
<aura:component implements="force:hasRecordId,
flexipage:availableForRecordHome">
<aura:attribute name="record"
type="Object"
description="The record object to be displayed"/>
<aura:attribute name="accountRecord"
type="Object"
description="A simplified view record object to be displayed"/>
<aura:attribute name="recordError"
type="Object"
description="An error message bound to force:recordData"/>
<force:recordData aura:id="accountRecordId"
recordId="{!v.recordId}"
layoutType="FULL"
mode="VIEW"
targetRecord="{!v.record}"
targetFields="{!v.accountRecord}" targetError="{!v.recordError}"/>
<!-- Display a lightning card with details about the record -->
<div class="Record Details">
<lightning:card iconName="standard:account" title="{!v.accountRecord.Name}">
<div class="slds-p-horizontal--small">
<p>
<lightning:formattedText title="Industry" value="{!v.accountRecord.Industry}"/>
</p>
<p>
<lightning:formattedText title="Description" value="{!v.accountRecord.Description}"/>
</p>
<p>
<lightning:formattedPhone title="Phone" value="{!v.accountRecord.Phone}"/>
</p>
</div>
</lightning:card>
</div>
</aura:component>
accEdit.cmp
<aura:component implements="force:hasRecordId,
flexipage:availableForRecordHome">
<aura:attribute name="record"
type="Object"
description="The record object to be displayed"/>
<aura:attribute name="accountRecord"
type="Object"
description="A simplified view record object to be displayed"/>
<aura:attribute name="recordError"
type="Object"
description="An error message bound to force:recordData"/>
<force:recordData aura:id="accountRecordId"
recordId="{!v.recordId}"
fields="Name"
mode="EDIT"
targetRecord="{!v.record}"
targetFields="{!v.simpleRecord}"
targetError="{!v.recordError}"/>
<!-- Display an editing form -->
<div class="Record Details">
<lightning:card iconName="action:edit" title="Edit Account">
<div class="slds-p-horizontal--small">
<lightning:input label="Account Name" value="{!v.accountRecord.Name}"/>
<br/>
<lightning:button label="Save Account" variant="brand" onclick="{!c.handleSaveRecord}" />
</div>
</lightning:card>
</div>
<!-- Display Lightning Data Service errors, if any -->
<aura:if isTrue="{!not(empty(v.recordError))}">
<div class="recordError">
{!v.recordError}
</div>
</aura:if>
</aura:component>
accEditController.js
({
handleSaveRecord : function(component, event, helper) {
component.find("accountRecordId").saveRecord($A.getCallback(function(saveResult) {
if (saveResult.state === "SUCCESS" || saveResult.state === "DRAFT") {
console.log("Save completed successfully.");
} else if (saveResult.state === "INCOMPLETE") {
console.log("User is offline, device doesn't support drafts.");
} else if (saveResult.state === "ERROR") {
console.log('Problem saving record, error: ' +
JSON.stringify(saveResult.error));
} else {
console.log('Unknown problem, state: ' + saveResult.state + ', error: ' + JSON.stringify(saveResult.error));
}
}));
}
})
Handle Record Changes and Errors
data:image/s3,"s3://crabby-images/567ba/567bacbd38b4121ef64cd27fd0b0dcc047d52c44" alt=""
accEdit.cmp
<aura:component implements="force:hasRecordId,flexipage:availableForRecordHome">
<aura:attribute name="record"
type="Object"
description="The record object to be displayed"/>
<aura:attribute name="accountRecord"
type="Object"
description="A simplified view record object to be displayed"/>
<aura:attribute name="recordSaveError"
type="String"
description="An error message bound to force:recordData"/>
<force:recordData aura:id="accountRecordId"
recordId="{!v.recordId}"
fields="Name"
mode="EDIT"
targetRecord="{!v.record}"
targetFields="{!v.simpleRecord}"
targetError="{!v.recordSaveError}"/>
<!-- Display an editing form -->
<div class="Record Details">
<lightning:card iconName="action:edit" title="Edit Account">
<div class="slds-p-horizontal--small">
<lightning:input label="Account Name" value="{!v.accountRecord.Name}"/>
<br/>
<lightning:button label="Save Account" variant="brand" onclick="{!c.handleSaveRecord}" />
</div>
</lightning:card>
</div>
<!-- Display Lightning Data Service errors, if any -->
<aura:if isTrue="{!not(empty(v.recordSaveError))}">
<div class="recordError">
{!v.recordSaveError}
</div>
</aura:if>
</aura:component>
accEditController.js
({
handleSaveRecord : function(component, event, helper) {
component.find("accountRecordId").saveRecord($A.getCallback(function(saveResult) {
if (saveResult.state === "SUCCESS" || saveResult.state === "DRAFT") {
console.log("Save completed successfully.");
} else if (saveResult.state === "INCOMPLETE") {
console.log("User is offline, device doesn't support drafts.");
} else if (saveResult.state === "ERROR") {
console.log('Problem saving record, error: ' +
JSON.stringify(saveResult.error));
var errMsg = "";
for (var i = 0; i < saveResult.error.length; i++) {
errMsg += saveResult.error[i].message + "\n";
}
component.set("v.recordSaveError", errMsg);
} else {
console.log('Unknown problem, state: ' + saveResult.state + ', error: ' + JSON.stringify(saveResult.error));
}
}));
}
})
data:image/s3,"s3://crabby-images/21fee/21feec39c28e1fbb90580938b803e9bb8bc27046" alt=""
Lightning Design System
https://trailhead.salesforce.com/en/content/learn/modules/lightning_design_system
Understand Key Principles Behind the Design System
data:image/s3,"s3://crabby-images/38fb3/38fb3a1fcbda7b54167a991dce068d8d73c15019" alt=""
data:image/s3,"s3://crabby-images/da696/da69661102aa2c7666035338ec22abf0ef051700" alt=""
data:image/s3,"s3://crabby-images/eb272/eb27239c6d5da284f951545b2b1ed5186805639c" alt=""
Get Started with the Design System
https://trailhead.salesforce.com/content/learn/modules/lightning_design_system/lightning-design-system2
data:image/s3,"s3://crabby-images/27d03/27d039bf7cdfada6e9be4a95b702d865caf29a21" alt=""
data:image/s3,"s3://crabby-images/a2937/a2937320588db300bb07637f1c5591480a7c0a57" alt=""
Understand the Grid System
data:image/s3,"s3://crabby-images/75ddf/75ddf8435f143769f610ff7a676c73ca8ebce86f" alt=""
data:image/s3,"s3://crabby-images/20d84/20d8482261c02606f86dc1bca82318fab0853123" alt=""
data:image/s3,"s3://crabby-images/8bce4/8bce4d84b8c89c45d9d2b24c56202af7ae8c6e1a" alt=""
Work with Salesforce Data
data:image/s3,"s3://crabby-images/8f93f/8f93ff29372e15e81feca1afdbf5cffadde5cbb7" alt=""
data:image/s3,"s3://crabby-images/1e04e/1e04e6ff94506555463861d6227a71f57e7e77a9" alt=""
data:image/s3,"s3://crabby-images/0f744/0f744ac639c2b6ab07f3f2fa99ff1380967770a5" alt=""
Use Images, Icons, and Avatars
data:image/s3,"s3://crabby-images/f4ff7/f4ff7bfadec61698ad26a48944a548540e40d07b" alt=""
data:image/s3,"s3://crabby-images/1e809/1e809f5389b1d26f3a1d161338cba54ceac8979a" alt=""
data:image/s3,"s3://crabby-images/246f0/246f0a520359f7b8fbf969a0d3fbbaa6ce944993" alt=""
Lay Out a Record Home Page and Using Advanced Components
https://trailhead.salesforce.com/content/learn/modules/lightning_design_system/lightning-design-system6
data:image/s3,"s3://crabby-images/a3319/a3319305d309250a9e479735179ebb4fe756c058" alt=""
data:image/s3,"s3://crabby-images/17ab8/17ab8d4041ee1ba927366a6cb29cc4f9c795637e" alt=""
下面正式进入解锁SB阶段:
https://trailhead.salesforce.com/en/content/learn/superbadges/superbadge_lcf
data:image/s3,"s3://crabby-images/c2774/c2774c4862bd3b2aecad01314608988f413b19cf" alt=""
https://login.salesforce.com/packaging/installPackage.apexp?p0=04tf40000011Bh4
data:image/s3,"s3://crabby-images/e7202/e7202f63e1b60a5dd41ff4ad8e98c9a0acbfbde6" alt=""
网友评论