⚠️注意:以下の例ではURLからLWCを呼ぶことを想定しているため、モーダルで起動できません。
手順
- URLパラメータなしの場合
- URLパラメータありの場合
URLパラメータなしの場合
1. Lightning Web Componentの作成
<template>
<p>HelloWorld!!</p>
</template>
import { LightningElement } from 'lwc';
export default class HelloWorld extends LightningElement {}
2. URLリンク先となるAura Componentの作成
<!-- lightning:isUrlAddressableを実装することでURLからの遷移を可能とする -->
<aura:component implements="lightning:isUrlAddressable">
<!-- LWCを呼ぶ。↓↓↓-->
<c:helloWorld />
</aura:component>
3. Aura Componentを呼ぶボタンを作成
以下のURLでボタンを作成。
/lightning/cmp/c__HelloWorldUrl
URLパラメータありの場合
1. Lightning Web Componentの作成
<template>
<!-- カードのタイトルにURLパラメータで受け取った文字列を表示 -->
<lightning-card title={title}>
<p>HelloWorld!!</p>
</lightning-card>
</template>
import { LightningElement, api } from 'lwc';
export default class HelloWorld extends LightningElement {
// URLパラメータから受け取る変数を用意
@api title;
}
2. URLリンク先となるAura Componentの作成
<!-- lightning:isUrlAddressableを実装することでURLからの遷移を可能とする -->
<aura:component implements="lightning:isUrlAddressable">
<!-- URLパラメータから値を取得する場合パラメータ名を設定。c__[パラメータ名]で取得可能 -->
<aura:attribute name="title" type="String" />
<!-- 画面起動時にURLパラメータを取得 -->
<aura:handler name="init" value="{!this}" action="{!c.onPageReferenceChange}"/>
<!-- 2度目の画面起動時ではinitハンドラーが起動しないため、パラメータのchangeハンドラーを使い再度URLパラメータを設定 -->
<aura:handler name="change" value="{!v.pageReference}" action="{!c.onPageReferenceChange}"/>
<!-- URLパラメータ値を渡しながらLWCを呼ぶ。パラメータはキャメルでも問題ない。 -->
<c:helloWorld title="{!v.title}" />
</aura:component>
({
onPageReferenceChange: function(cmp, evt, helper) {
var myPageRef = cmp.get("v.pageReference");
var title = myPageRef.state.c__title;
cmp.set("v.title", title);
}
})
3. Aura Componentを呼ぶボタンを作成
以下のURLでボタンを作成。
/lightning/cmp/c__HelloWorldUrl?c__title={!Object__c.Name}
Is Url Addressable
https://developer.salesforce.com/docs/component-library/bundle/lightning:isUrlAddressable/documentation