Skip to main content

アプリケーションのコンポーネントとの通信

メモ

メモ

日本語で受講されている方へ
Challenge は日本語の Trailhead Playground で開始し、かっこ内の翻訳を参照しながら進めていってください。Challenge での評価は英語データを対象に行われるため、英語の値のみをコピーして貼り付けるようにしてください。日本語の組織で Challenge が不合格だった場合は、(1) この手順に従って [Locale (地域)] を [United States (米国)] に切り替え、(2) [Language (言語)] を [English (英語)] に切り替えてから、(3) [Check Challenge (Challenge を確認)] ボタンをクリックしてみることをお勧めします。

翻訳版 Trailhead を活用する方法の詳細は、自分の言語の Trailhead バッジを参照してください。

Bear List (熊リスト) コンポーネントを更新する

パークレンジャーから最後にもう 1 つ依頼があります。彼らは熊リストを絞り込むときに、地図で熊の位置を確認したいと考えています。熊の地図コンポーネントを作成し、イベントが地図に送信されるよう熊リストを変更する必要があります。まず熊リストの更新から始めましょう。

  1. bearList.js ファイルを編集します。
  2. import { NavigationMixin } from 'lightning/navigation'; の前に次のコードを追加します:
    import { publish, MessageContext } from 'lightning/messageService';
    import BEAR_LIST_UPDATE_MESSAGE from '@salesforce/messageChannel/BearListUpdate__c';
    最初のインポートでは、Lightning Messaging Service (LMS) からユーティリティが取得されます。このサービスを利用すると、Lightning メッセージチャネルを通じて Lightning ページの兄弟コンポーネント全体にメッセージを公開することができます。
    2 番目のインポートは、GitHub から取得したベースプロジェクトに含まれていた Lightning メッセージチャネルです。
  3. 次の 2 行を
    @wire(searchBears, {searchTerm: '$searchTerm'})
    bears;
    次のコードに置き換えます。
    bears;
    @wire(MessageContext) messageContext;
    @wire(searchBears, {searchTerm: '$searchTerm'})
    loadBears(result) {
      this.bears = result;
      if (result.data) {
        const message = {
          bears: result.data
        };
        publish(this.messageContext, BEAR_LIST_UPDATE_MESSAGE, message);
      }
    }
    コードのポイント:
    • Lightning メッセージを取得し、messageContext プロパティに保存します。
    • wired 関数を使用して、受信される熊リストデータを取得し、熊レコードのリストを使用してカスタムの BearListUpdate__c Lightning メッセージを起動します。
    • searchTerm が変更されるたびに loadBears が再実行されるように、結び付けられた searchBears アダプターに searchTerm を動的パラメーターとして渡し、新しい検索結果を使用して新しいメッセージを起動します。
    • ここでは、LMS からインポートした publish 関数を使用して、熊リストで BearListUpdate__c Lightning メッセージを起動します。

Bear Map (熊の地図) コンポーネントを作成する

  1. VS Code で、lwc フォルダーを右クリックして [SFDX: Create Lightning Web Component (SFDX: Lightning Web コンポーネントを作成)] をクリックします。
  2. コンポーネントに「bearMap」と名前を付けます。
  3. bearMap.js-meta.xml ファイルを編集して <isExposed>false</isExposed> を次の行に置き換えます。
    <isExposed>true</isExposed>
    <targets>
    	<target>lightning__AppPage</target>
    	<target>lightning__RecordPage</target>
    	<target>lightning__HomePage</target>
    </targets>
    これで、あらゆる種別のページにコンポーネントを配置できます。
  4. bearMap.html の内容を次に置き換えます。
    <template>
    	<article class="slds-card">
    		<lightning-map
    			map-markers={mapMarkers}
    			zoom-level="11"
    			markers-title="Bears">
    		</lightning-map>
    	</article>
    </template>
    コードのポイント:
    • 地図を含むカードコンポーネントを表示します。
    • 地図には、mapMarkers 配列の項目が表示されます。
  5. bearMap.js の内容を次に置き換えます。
    import { LightningElement, wire } from 'lwc';
    import { subscribe, unsubscribe, MessageContext } from 'lightning/messageService';
    import BEAR_LIST_UPDATE_MESSAGE from '@salesforce/messageChannel/BearListUpdate__c';
    export default class BearMap extends LightningElement {
      mapMarkers = [];
      subscription = null;
      @wire(MessageContext)
      messageContext;
      connectedCallback() {
        // Subscribe to BearListUpdate__c message
        this.subscription = subscribe(
            this.messageContext,
            BEAR_LIST_UPDATE_MESSAGE,
            (message) => {
                this.handleBearListUpdate(message);
            });
      }
      disconnectedCallback() {
        // Unsubscribe from BearListUpdate__c message
        unsubscribe(this.subscription);
        this.subscription = null;
      }
      handleBearListUpdate(message) {
        this.mapMarkers = message.bears.map(bear => {
          const Latitude = bear.Location__Latitude__s;
          const Longitude = bear.Location__Longitude__s;
          return {
            location: { Latitude, Longitude },
            title: bear.Name,
            description: `Coords: ${Latitude}, ${Longitude}`,
            icon: 'utility:animal_and_nature'
          };
        });
      }
    }
    コードのポイント:
    • connectedCallbackdisconnectedCallback というコンポーネントライフサイクルのフック関数を 2 つ実装しました。これらは、コンポーネントの読み込み時と読み込み解除時に自動的にコールされます。これら 2 つの関数を使用して、BearListUpdate__c Lightning メッセージの登録/登録解除を行います。
    • BearListUpdate__c イベントを受信すると、現在絞り込まれている熊レコードのリストを使用して handleBearListUpdate 関数がただちにコールされます。mapMarkers プロパティに渡されて地図コンポーネントに表示される地図マーカーのリストが handleBearListUpdate によって作成されます。
  6. 更新したコードを組織にリリースします。default フォルダーを右クリックして [SFDX: Deploy Source to Org (SFDX: 組織にソースをリリース)] をクリックします。

Bear Map (熊の地図) コンポーネントをアプリケーションのホームページに追加する

新しいコンポーネントをアプリケーションのホームページに追加しましょう。

  1. 組織に戻り、アプリケーションランチャー (アプリケーションランチャー) で、[Ursus Park] を見つけて選択します。
  2. [Setup (設定)] (設定歯車) をクリックして、[Edit Page (編集ページ)] を選択します。
  3. [Custom (カスタム)] コンポーネントで bearMap コンポーネントを見つけ、ページの左上にドラッグします。
  4. [Save (保存)] をクリックしてから、[Back (戻る)] をクリックしてホームページに戻り、熊リストを絞り込んだときに地図が更新されることを確認します。

絞り込まれた熊レコードを表示する熊の地図

プロジェクトのまとめ

これで完了です。パークレンジャーは、あなたのおかげで熊を簡単に追跡できるようになりました。

このプロジェクトでは、データバインド、式、条件に応じた表示、命令型およびワイヤード Apex、コンポーネントのコンポジション、コンポーネント間イベントという、Lightning Web コンポーネントの核心概念をすべて使用しました。

Lightning Web コンポーネントを使用した独自の柔軟なアプリケーションを構築して、この知識を活用してください。それでは、コーディングをお楽しみください!

Salesforce ヘルプで Trailhead のフィードバックを共有してください。

Trailhead についての感想をお聞かせください。[Salesforce ヘルプ] サイトから新しいフィードバックフォームにいつでもアクセスできるようになりました。

詳細はこちら フィードバックの共有に進む