action メソッドの定義
action メソッドは、ユーザーがボタンをクリックしたり、ページ内のある領域にマウスポインターを移動したりするなどのページイベントが発生すると、ロジックまたはナビゲーションを実行します。次のいずれかのタグの action パラメーターに {! } 表記を使用することによって、ページマークアップから action メソッドをコールできます。
- <apex:commandButton> はアクションをコールするボタンを作成する
- <apex:commandLink> はアクションをコールするリンクを作成する
- <apex:actionPoller> は定期的にアクションをコールする
- <apex:actionSupport> は、別の名前つきのコンポーネントにイベント (「onclick」、「onmouseover」など) を作成し、アクションをコールする
- <apex:actionFunction> は、アクションをコールする新しい JavaScript 関数を定義する
- <apex:page> はページが読み込まれると、アクションをコールする
たとえば、「ページでの入力コンポーネントの使用」で説明されているサンプルページでは、コマンドボタンは、標準取引先コントローラーの save メソッドにバインドされています。MyController カスタムコントローラーを使用するように、前の例を適応させることができます。
1<apex:page controller="MyController" tabStyle="Account">
2 <apex:form>
3 <apex:pageBlock title="Hello {!$User.FirstName}!">
4 You are viewing the {!account.name} account. <p/>
5 Change Account Name: <p/>
6 <apex:inputField value="{!account.name}"/> <p/>
7 <apex:commandButton action="{!save}" value="Save New Account Name"/>
8 </apex:pageBlock>
9 </apex:form>
10</apex:page>上記のページを保存すると、Visualforce エディターで「クイック修正」オプションを使用して、MyController クラスに save メソッドを追加できます。クイック修正リンクをクリックすると、MyController は次のようになります。
1public class MyController {
2
3 public PageReference save() {
4 return null;
5 }
6
7 public String getName() {
8 return 'MyController';
9 }
10
11 public Account getAccount() {
12 return [select id, name from Account
13 where id = :ApexPages.currentPage().getParameters().get('id')];
14 }
15}クイック修正によって生成される save メソッドは、action メソッドに使用する標準署名を使用します。これは public であり、PageReferemce を返し、引数を含みません。
最終的に、save メソッドの定義は、新しい取引先値を使用してデータベースを更新する必要がありますが、まずその前にメンバー変数を定義して、データベースから取得される取引先情報を保存する必要があります。取引先のメンバー変数がない場合、データベースから取得されるレコードは、その値がページを表示するために使用された後で保持されないため、ユーザーによるレコード更新は保存できません。このメンバー変数を導入するには、コントローラーコードの 2 つの部分を変更する必要があります。
- メンバー変数をクラスに追加する
- getAccount が最初のクエリを実行するときにメンバー変数を設定する
1public class MyController {
2
3 Account account;
4
5 public PageReference save() {
6 return null;
7 }
8
9 public String getName() {
10 return 'MyController';
11 }
12
13 public Account getAccount() {
14 if(account == null)
15 account = [select id, name, site from Account
16 where id = :ApexPages.currentPage().getParameters().get('id')];
17 return account;
18 }
19}メンバー変数が適切に配置されたため、save メソッドで行う必要があることはデータベースの更新だけです。
1public class MyController {
2
3 Account account;
4
5 public PageReference save() {
6 update account;
7 return null;
8 }
9
10 public String getName() {
11 return 'MyController';
12 }
13
14 public Account getAccount() {
15 if(account == null)
16 account = [select id, name, site from Account
17 where id = :ApexPages.currentPage().getParameters().get('id')];
18 return account;
19 }
20}save に対するより堅牢なソリューションとしては、さまざまな例外の検出や重複の検索などを行うことが考えられます。ここでは単純な例を示すことを目的としているため、そのような詳細は省略しています。
このページをテストするために、[取引先名を変更] 項目の値を変更して、[新規取引先名を保存] をクリックします。標準取引先コントローラーの例と同様に、ページは単に新しい取引先名で更新されます。次の例では、save アクションを拡張して、現在のページを更新する代わりにユーザーを別の確認ページに移動します。