この文章は Salesforce 機械翻訳システムを使用して翻訳されました。詳細はこちらをご参照ください。
英語に切り替える

$Component を使用した JavaScript からのコンポーネントの参照

$Component グローバル変数を使用すると、Visualforce コンポーネント用に生成される DOM ID の参照が簡略化され、ページ構造全体での連動関係の一部が削減されます。

どの Visualforce タグにも id 属性が含まれています。他のタグでタグの id 属性を使用することにより、その 2 つのタグをバインドすることができます。たとえば、<apex:outputLabel> タグの for 属性を <apex:inputField> タグの id 属性と併用することができます。<apex:actionFunction><apex:actionSupport>、およびその他の活動指向型のコンポーネントの reRender 属性および status 属性もその他のコンポーネントの id 属性の値を使用します。

この ID は、複数の Visualforce コンポーネントのバインドに使用されるだけでなく、ページを表示する際のコンポーネントのドキュメントオブジェクトモデル (DOM) ID の一部の形成にも使用されます。

JavaScript または他の Web 対応言語で Visualforce コンポーネントを参照するには、そのコンポーネントの id 属性の値を指定する必要があります。DOM ID はコンポーネントの id 属性とその要素を含むすべてのコンポーネントの id 属性の組み合わせで構成されます。

コンポーネントアクセスの例

次の例では、<apex:outputPanel> タグの DOM ID を使用します。このページには 2 つのパネルがあります。最初のパネルには DOM イベントをトリガするチェックボックスがあり、2 番目のパネルにはイベントに応じて変わるいくつかのテキストが含まれています。

ページの上部には、<script> HTML タグ内に含まれる JavaScript があります。イベント (input) をトリガした要素および影響を受けるテキストを含む対象のパネルの DOM ID (textid) を引数としてとります。

1<apex:page id="thePage">
2    <!-- A simple function for changing the font. -->
3    <script>
4        function changeFont(input, textid) {
5            if(input.checked) {
6                document.getElementById(textid).style.fontWeight = "bold";
7            }
8            else {
9                document.getElementById(textid).style.fontWeight = "normal";
10            }
11        }
12    </script>
13
14    <!-- This outputPanel calls the function, passing in the
15         checkbox itself, and the DOM ID of the target component. -->
16    <apex:outputPanel layout="block">
17        <label for="checkbox">Click this box to change text font:</label>
18        <input id="checkbox" type="checkbox"
19            onclick="changeFont(this,'{!$Component.thePanel}');"/>
20    </apex:outputPanel>
21
22    <!-- This outputPanel is the target, and contains 
23         text that will be changed. -->
24    <apex:outputPanel id="thePanel" layout="block">
25        Change my font weight!
26    </apex:outputPanel>
27</apex:page>

{!$Component.thePanel} 式は、<apex:outputPanel id="thePanel"> コンポーネントによって生成される HTML 要素の DOM ID を取得するために使用されます。