Skip to main content

Usar o Lightning Data Service para trabalhar com dados

Objetivos de aprendizagem

Após concluir esta unidade, você estará apto a:

  • Criar soluções que incluam componentes básicos lightning-record-*-form.
  • Usar os adaptadores de conexão do Lightning Data Service (LDS) para ler dados.
  • Usar as funções do LDS para modificar dados.
Nota

Nota

Deseja aprender em português (Brasil)? Nesse emblema, as validações dos desafios práticos do Trailhead funcionam em inglês. As traduções são fornecidas entre parênteses como referência No Trailhead Playground, (1) mude a localidade para Estados Unidos, (2) mude o idioma para inglês e (3) copie e cole apenas os valores em inglês. Siga as instruções aqui.

Consulte o emblema Trailhead no seu idioma para saber mais sobre como aproveitar a experiência de Trailhead em outros idiomas.

Se essa for sua primeira incursão nos componentes Web do Lightning, espere. Dê um passo para trás. Antes de trabalhar neste módulo, conclua o módulo Noções básicas dos componentes Web do Lightning e a trilha Aprender a trabalhar com o JavaScript aqui no Trailhead. O trabalho aqui realizado se baseia nos conceitos e no trabalho realizado em ambos.

Trabalhar com dados em componentes Web do Lightning

Nos componentes Web do Lightning, existem várias maneiras de trabalhar com os dados do Salesforce. Saber qual solução usar para cada caso de uso permite que você escreva um código menor, mais simples e mais sustentável. Usar a melhor solução para cada situação também melhora o desempenho de seus componentes e aplicativos.

Neste módulo, você aprenderá quando e como usar soluções diferentes. Analisaremos primeiro as opções mais fáceis, mas menos personalizáveis. Mais tarde, consideraremos opções mais complexas e mais personalizáveis.

Trabalhar com dados usando o Lightning Data Service

O Lightning Data Service é a maneira preferencial (e mais fácil) de trabalhar com os dados do Salesforce. Com o Lightning Data Service, os desenvolvedores usam o JavaScript para conectar componentes a dados do Salesforce.

O Lightning Data Service também oferece segurança ao fazer chamadas ao servidor para proteger os pontos de extremidade da API de interface de usuário. Usando um cache compartilhado do lado do cliente em todos os componentes, o Lightning Data Service maximiza o desempenho. Quando um registro é armazenado em cache, ele é recuperado do cache, eliminando chamadas desnecessárias para o servidor.

O Lightning Data Service mantém dados uniformes e atualizados sobre vários componentes e clientes durante o ciclo de vida do aplicativo. Se vários componentes usam o Lightning Data Service para trabalhar com um registro e um deles atualiza o registro, os outros refletem automaticamente essa atualização.

Nas seções a seguir, destacamos diferentes maneiras de trabalhar com os dados do Salesforce usando o Lightning Data Service.

Ler ou modificar dados com componentes básicos do formulário de registro

A maneira mais fácil de trabalhar com registros únicos nos componentes Web do Lightning é usar os componentes do lightning-record-*-form. Esses componentes básicos usam o Lightning Data Service nos bastidores e herdam seus recursos de cache e sincronização. Cada componente básico oferece diferentes recursos e níveis de personalização.

  • O componente básico lightning-record-form é o mais simples deles. Com o lightning-record-form, você pode especificar um layout e permitir que os administradores configurem campos de formulário de forma declarativa. Você também pode especificar uma lista ordenada de campos para definir programaticamente o que é exibido. lightning-record-form permite que você visualize e edite registros.
  • O componente básico lightning-record-view-form permite a visualização de registros.
  • O componente básico lightning-record-edit-form permite a edição de registros.

Escolha lightning-record-view-form ou lightning-record-edit-form quando precisar personalizar o layout do formulário, preencher valores de campo ou alterar como os dados do registro são renderizados.

Veja um exemplo que usa lightning-record-form para criar contas.

accountCreator.html

<template>
    <lightning-card>
        <lightning-record-form
            object-api-name={objectApiName}
            fields={fields}
            onsuccess={handleSuccess}>
        </lightning-record-form>
    </lightning-card>
</template>

accountCreator.js

import { LightningElement } from 'lwc';
import { ShowToastEvent } from 'lightning/platformShowToastEvent';
import ACCOUNT_OBJECT from '@salesforce/schema/Account';
import NAME_FIELD from '@salesforce/schema/Account.Name';
import REVENUE_FIELD from '@salesforce/schema/Account.AnnualRevenue';
import INDUSTRY_FIELD from '@salesforce/schema/Account.Industry';
export default class AccountCreator extends LightningElement {
    objectApiName = ACCOUNT_OBJECT;
    fields = [NAME_FIELD, REVENUE_FIELD, INDUSTRY_FIELD];
    handleSuccess(event) {
        const toastEvent = new ShowToastEvent({
            title: "Account created",
            message: "Record ID: " + event.detail.id,
            variant: "success"
        });
        this.dispatchEvent(toastEvent);
    }
}

Destaques do código:

accountCreator.html 

  • Linha 3: usando lightning-record-form na marcação, recebemos todos os benefícios de segurança e desempenho que o Lightning Data Service oferece. Quando lightning-record-form não especifica recordId, ele opera no modo edit e cria um registro ao enviar.
  • Linha 4: a vinculação da propriedade object-api-name indica o tipo de objeto a ser carregado.
  • Linha 5: a vinculação da propriedade fields indica os campos a serem exibidos no formulário.
  • Linha 6: definimos handleSuccess como o manipulador para o evento success.

accountCreator.js 

  • Linhas 3 a 6: no início do arquivo, importamos referências ao objeto Conta e aos seus campos. Fazer referência a objetos e campos dessa forma assegura a integridade referencial. O Salesforce verifica se o objeto e os campos existem, impede que eles sejam excluídos e garante que sejam incluídos em pacotes e conjuntos de alterações que fazem referência ao componente. Importar referências de objeto e campo garante que o código de seu componente ainda funcione se o objeto ou os campos forem renomeados.
  • Linha 10: definimos o manipulador de eventos handleSuccess para o evento success. handleSuccess é executado quando a operação de salvar é bem-sucedida.
  • Linhas 11 a 17: mostramos uma mensagem de notificação acionando ShowToastEvent, no qual o event.detail.id é uma referência à propriedade id do registro recém-criado.

Se precisar de mais personalização do que os componentes do lightning-record-*-form oferecem, você pode invocar diretamente o Lightning Data Service usando um adaptador de conexão ou uma função JavaScript. 

Ler dados com adaptadores de conexão do LDS

Os adaptadores de conexão do LDS são outra forma de trabalhar com os dados do Salesforce. Use um adaptador de conexão para ler dados do Salesforce (registros) e metadados (detalhes do layout, campos em um objeto e assim por diante). Para usá-los, decore uma propriedade ou função com @wire e especifique o adaptador de conexão.

Os adaptadores de conexão do LDS conferem o cache do LDS primeiro e solicitam dados do servidor apenas quando necessário. Os adaptadores reagem para alterar e atualizar os dados de acordo. Por exemplo, quando o valor do parâmetro é alterado ou outros componentes modificam dados no cache do Lightning Data Service, um adaptador provisiona os novos dados à propriedade ou função conectada.

Vamos analisar um exemplo que usa o adaptador de conexão getRecord.

wireGetRecordProperty.js

import { LightningElement, api, wire } from 'lwc';
import { getRecord, getFieldValue } from 'lightning/uiRecordApi';
import ACCOUNT_NAME_FIELD from '@salesforce/schema/Account.Name';
export default class WireGetRecordProperty extends LightningElement {
    @api recordId;
    @wire(getRecord, { recordId: '$recordId', fields: [ACCOUNT_NAME_FIELD] })
    account;
    get name() {
        return getFieldValue(this.account.data, ACCOUNT_NAME_FIELD);
    }
}

Destaques do código:

  • Linha 2: Importamos o adaptador de conexão getRecord e a função getFieldValue.
  • Linha 3: assim como fizemos no exemplo accountCreator, importamos uma referência para o campo Account.Name. (Na linha 6, usamos isso para informar ao adaptador de conexão getRecord quais campos recuperar.)
  • Linha 5: quando o componente wireGetRecordProperty é colocado em uma página de registro, @api recordId permite que o componente pai (o FlexiPage) passe a ID do registro atual para o componente.
  • Linha 6: para conectar a propriedade da conta, aplicamos o decorador @wire e especificamos o adaptador de conexão para chamar (getRecord), bem como os parâmetros de que o adaptador precisa (recordId e fields).
  • Linha 7: o adaptador de conexão provisiona um fluxo de valores à propriedade account, que será definido várias vezes. Se um registro for recuperado, ele será armazenado em account.data. Se a recuperação de registro falhar, o erro será armazenado em account.error.
  • Linhas 6 a 7: na primeira vez que um valor é atribuído à propriedade recordId, o adaptador de conexão obtém os dados do servidor e os armazena no cache do LDS para acesso futuro. Ao passar o parâmetro recordId como uma string com prefixo $, tornamos recordId reativo. Toda vez que o valor de recordId é alterado, o adaptador de conexão obtém novos dados, seja no cache ou no servidor. Se outro componente modificar o registro em cache, o adaptador de conexão provisiona o novo valor do registro à propriedade account.
  • Linhas 8 a 10: Definimos um getter para a propriedade name. A função getFieldValue dá acesso aos valores do campo por meio dos dados retornados.

Neste exemplo, a propriedade name pode ser recuperada no arquivo HTML do seguinte modo:

wireGetRecordProperty.html

<template>
  Account Name: {name}
</template>

wireGetRecordProperty é um exemplo de decoração de propriedade. Podemos decorar uma função da mesma forma. Isso é útil quando você deseja executar alguma lógica sobre os registros retornados. Aqui está o exemplo anterior (wireGetRecordProperty), retrabalhado para conectar uma função (wiredAccount) em vez de uma propriedade.

wireGetRecordFunction.js

import { LightningElement, api, wire } from 'lwc';
import { getRecord, getFieldValue } from 'lightning/uiRecordApi';
import ACCOUNT_NAME_FIELD from '@salesforce/schema/Account.Name';
export default class WireGetRecord extends LightningElement {
    @api recordId;
    data;
    error;
    @wire(getRecord, { recordId: '$recordId', fields: [ACCOUNT_NAME_FIELD] })
    wiredAccount({data, error}) {
        console.log('Execute logic each time a new value is provisioned');
        if (data) {
            this.data = data;
            this.error = undefined;
        } else if (error) {
            this.error = error;
            this.data = undefined;
        }
    }
    get name() {
        return getFieldValue(this.data, ACCOUNT_NAME_FIELD);
    }
}

Destaques do código:

  • Linhas 8 a 9: Em vez de decorar uma propriedade, vamos decorar a função wiredAccount. A função recupera, como um parâmetro, um objeto que tem dois atributos: data e error. Usamos a desestruturação ES6 de objeto para descompactar os atributos do objeto.
  • Linhas 11 a 17: Como os adaptadores de conexão do LDS não provisionam um único valor, mas sim um fluxo de valores, a função wiredAccount pode ser invocada várias vezes. Como resultado, a função conectada deve redefinir os estados que ela influencia. Então, aqui, nas linhas 11 a 17, se o adaptador de conexão provisiona novos dados, armazenamos esses dados na propriedade data e definimos a propriedade error como indefinida. Como alternativa, se houver um erro, armazenamos o erro na propriedade error e definimos a propriedade data como indefinida.

Neste exemplo, podemos acessar a propriedade name da mesma forma que a acessamos no exemplo anterior.

Modificar dados com funções do LDS

Os adaptadores de conexão do LDS são ótimos para ler dados, mas para criar, atualizar ou excluir registros, você precisa de uma função do LDS. Observe que, embora os adaptadores de conexão sejam invocados pelo mecanismo dos componentes Web do Lightning, as funções são invocadas imperativamente. As funções do LDS notificam o cache do LDS quando registros são criados, atualizados ou excluídos. Considere este exemplo, que usa a função do LDS createRecord para criar um registro de conta.

ldsCreateRecord.js

import { LightningElement} from 'lwc';
import { createRecord } from 'lightning/uiRecordApi';
import ACCOUNT_OBJECT from '@salesforce/schema/Account';
import ACCOUNT_NAME_FIELD from '@salesforce/schema/Account.Name';
export default class LdsCreateRecord extends LightningElement {
    handleButtonClick() {
        const recordInput = {
            apiName: ACCOUNT_OBJECT.objectApiName,
            fields: {
                [ACCOUNT_NAME_FIELD.fieldApiName] : 'ACME'
            }
        };
        createRecord(recordInput)
            .then(account => {
                // code to execute if create operation is successful
            })
            .catch(error => {
                // code to execute if create operation is not successful
            });
    }
}

Destaques do código:

  • Linha 2: importamos a função do LDS createRecord.
  • Linhas 3 a 4: importamos o objeto Account e o campo Account.Name (como fizemos nos exemplos anteriores) para garantir a integridade referencial.
  • Linha 6: definimos o método handleButtonClick como um manipulador de eventos. Ele responde ao evento que ocorre quando um usuário clica em um lightning-button no arquivo .html (não mostrado). Quando handleButtonClick é invocado, ele invoca a função CreateRecord imperativamente.
  • Linha 10: nosso manipulador de eventos transmite uma string para o campo Account.Name, necessário para o adaptador criar uma nova conta.
  • Linha 13: quando invocamos uma função do LDS imperativamente, ela retorna uma promessa (um objeto do JavaScript que simplifica a execução de chamadas assíncronas).
  • Linhas 14 a 16: no método then, definimos o que acontece se a conta for criada com sucesso.
  • Linhas 17 a 19: no método catch, definimos o que acontece se a criação da conta falhar.

Nota:  as funções do LDS permitem que você trabalhe somente com registros individuais. Embora você possa usar várias funções no mesmo componente (para criar dois tipos diferentes de registros na mesma operação, por exemplo), cada função é executada em sua própria transação independente. Portanto, não há lógica de reversão comum. Se você precisar que uma operação DML combinada seja transacional, cogite usar o Apex.

Para saber mais sobre os adaptadores e funções de conexão do LDS e como usá-los, visite o Guia do desenvolvedor de componentes Web do Lightning e o blog de desenvolvedores do Salesforce.

Implantar um componente Web do Lightning que cria contas

Agora que analisamos diferentes maneiras de trabalhar com o Lightning Data Service, vamos trabalhar em um exemplo.

Antes de começar

Presumimos que você tem seu ambiente de desenvolvimento Salesforce DX configurado, e se sente confortável em usá-lo para criar componentes Web do Lightning e implantá-los em uma organização. Se você ainda não está familiarizado com esse processo, conclua o projeto Início rápido: Componentes Web do Lightning.

Criar um novo Trailhead Playground

Para este projeto, é preciso criar um novo Trailhead Playground. Role até a parte inferior desta página, clique na seta para baixo ao lado de Iniciar e selecione Criar um Trailhead Playground. Normalmente, leva de 3 a 4 minutos para criar um novo Trailhead Playground.

Nota:  sim, estamos falando de um Trailhead Playground totalmente novo! Se você estiver usando uma organização ou um playground existente, poderá ter problemas na hora de concluir os desafios.

Obtenha seu nome de usuário e senha para o Trailhead Playground

Vá ao seu Trailhead Playground. (Caso não esteja aberto, role até o fim desta página e clique em Iniciar.) Se você vir uma guia na sua organização com o rótulo Obter suas credenciais de login, ótimo! Avance para a etapa 1. 

Caso contrário, no App Launcher (Iniciador de aplicativos) (Iniciador de aplicativos), encontre e abra o Playground Starter e siga as etapas. Se não vir o aplicativo Playground Starter, consulte Encontrar o nome de usuário e a senha para seu Trailhead Playground na Ajuda do Trailhead.

  1. Clique na guia Obter suas credenciais de login e anote seu nome de usuário.
  2. Clique em Redefinir minha senha. Isso envia um email para o endereço associado ao seu nome de usuário.
  3. Clique no link exibido no email.
  4. Insira uma nova senha, confirme-a e clique em Alterar senha.

Pronto para pôr a mão na massa? Vamos lá.

Neste exercício, você adiciona um componente Web do Lightning ao seu projeto e o implanta em seu Trailhead Playground. 

  1. Crie um novo projeto:
    1. Abra o Visual Studio Code.
    2. Abra a paleta de comandos: clique em Visualizar | Paleta de comandos.
    3. Na paleta de comandos, selecione SFDX: Criar projeto.
      Se não vir na lista, digite SFDX:Create Project (SFDX:Criar projeto) e pressione Enter.
    4. Aceite o modelo padrão.
    5. Como nome do projeto, insira workingWithDataInLWC e pressione Enter.
    6. Selecione um local para o novo projeto e clique em Criar projeto.
  2. Autorize seu Trailhead Playground:
    1. Na paleta de comandos, selecione (ou insira) SFDX: Autorizar uma organização.
    2. Selecione Produção: login.salesforce.com e pressione Enter.
    3. Em alias, insira lwc_and_salesforce_data e, em seguida, pressione Enter.
    4. Use o nome de usuário e a senha do Trailhead Playground para entrar.
    5. Quando você tiver feito login em seu Trailhead Playground, deixe-o aberto e volte para o Visual Studio Code.
  3. Crie um componente Web do Lightning:
    1. No painel do Explorer, clique com o botão direito na pasta lwc e selecione SFDX: Criar componente Web do Lightning.
    2. Como nome do componente, insira accountCreator e pressione Enter.
    3. Pressione Enter novamente para aceitar o diretório padrão.
  4. Substitua o conteúdo de seus arquivos accountCreator.html e accountCreator.js pelo código fornecido na seção Ler ou modificar dados com componentes básicos do formulário de registro, mostrada anteriormente nesta unidade.
  5. Para disponibilizar esse componente nas páginas do aplicativo em uma organização, substitua o conteúdo do seu arquivo accountCreator.js-meta.xml por este código:
    <?xml version="1.0" encoding="UTF-8"?>
    <LightningComponentBundle xmlns="http://soap.sforce.com/2006/04/metadata">
        <apiVersion>48.0</apiVersion>
        <isExposed>true</isExposed>
        <targets>
            <target>lightning__AppPage</target>
        </targets>
    </LightningComponentBundle>
  6. Salve os três arquivos: accountCreator.html, accountCreator.js e accountCreator.js-meta.xml.
  7. Implante os arquivos de projeto em seu Trailhead Playground. (Clique com o botão direito do mouse no diretório accountCreator e selecione SFDX: Implantar fonte para organização.)
  8. Se o Trailhead Playground não estiver aberto, abra-o. (Na paleta de comandos, selecione (ou insira) SFDX: Abrir organização padrão).
  9. Em seu Trailhead Playground, clique em Configuração e, em seguida, selecione Setup (Configuração).
  10. Na caixa Busca rápida, insira Criador de aplicativo Lightning e selecione Criador de aplicativo Lightning.
  11. Crie uma página do Lightning:
    1. Clique em Novo.
    2. Selecione Página de aplicativo e clique em Avançar.
    3. Em Rótulo, insira Working with Data e, então, clique em Avançar.
    4. Como layout, escolha Cabeçalho e barra lateral esquerda.
    5. Clique em Concluir.
  12. Arraste o componente accountCreator para a barra lateral da página.
  13. Salve a página.
  14. Ative a página: Mantenha o nome do aplicativo padrão (“Working with Data”) e clique em Salvar.
  15. Quando for solicitado que você adicione a página ao menu de navegação, clique em Concluir.
  16. Abra a nova página: Na pesquisa do Iniciador de aplicativos, insira work e selecione Working with Data.

Pronto. Você tem um componente Web do Lightning que usa lightning-record-form para criar registros de conta na página Working with Data. Usar o Lightning Data Service é uma maneira de trabalhar com os dados do Salesforce nos componentes Web do Lightning. Na próxima unidade, você aprenderá como usar o Apex para trabalhar com dados.

Recursos

Continue a aprender de graça!
Inscreva-se em uma conta para continuar.
O que você ganha com isso?
  • Receba recomendações personalizadas para suas metas de carreira
  • Pratique suas habilidades com desafios práticos e testes
  • Monitore e compartilhe seu progresso com os empregadores
  • Conecte-se a orientação e oportunidades de carreira