オブジェクトのプロパティに簡単にアクセスできるように、参照を作成する場合に煩雑さを省くためのショートカットが FormCalc に含まれています。このセクションでは、FormCalc の参照構文のショートカットを説明しています。
現在のフィールドまたはオブジェクト現在のフィールドまたはオブジェクトを参照します。
例$ = "Tony Blue"
上の例では現在のフィールドまたはオブジェクトの値を Tony Blue に設定します。
データモデル xfa.datasets.data のルートデータモデル xfa.datasets.data のルートを表します。
例$data.purchaseOrder.total
は、以下と等価です。
xfa.datasets.data.purchaseOrder.total
フォームオブジェクトのイベント現在のフォームオブジェクトのイベントを表します。
例$event.name
は、以下と等価です。
xfa.event.name
詳しくは、イベントモデルの使用を参照してください。
フォームモデルのルートフォームモデル xfa.form のルートを表します。
例$form.purchaseOrder.tax
は、次のステートメントと等価です。
xfa.form.purchaseOrder.tax
ホストのオブジェクトホストのオブジェクトを表します。
例$host.messageBox("Hello world")
は、以下と等価です。
xfa.host.messageBox("Hello world")
詳しくは、ホストアプリケーションの使用を参照してください。
レイアウトモデルのルートレイアウトモデル xfa.layout のルートを表します。
例$layout.ready
は、次のステートメントと等価です。
xfa.layout.ready
データレコードのコレクションXML ファイルといったデータコレクション内の現在のデータを表します。
例$record.header.txtOrderedByCity
は、txtOrderedByCity ノード(現在の XML データの header ノード内)を参照します。
テンプレートモデルのルートテンプレートモデル xfa.template のルートを表します。
例$template.purchaseOrder.item
は、以下と等価です。
xfa.template.purchaseOrder.item
xfa.datasets のデータモデルのルートデータモデル xfa.datasets のルートを表します。
例!data
は、以下と等価です。
xfa.datasets.data
すべてのフォームオブジェクトを選択名前と無関係にサブフォームなどの任意のコンテナ内にあるフォームオブジェクトをすべて選択したり、類似の名前を持つオブジェクトをすべて選択したりします。
resolveNode メソッドでは、「*」(アスタリスク)構文を JavaScript と共に使用できます。
例以下の式はフォームに item という名前を持つすべてのオブジェクトを選択します。
xfa.form.form1.item[*]
サブコンテナの一部のオブジェクトの検索参照構文の任意の場所に 2 つのピリオドを入力すると、現在のコンテナオブジェクトのサブコンテナを構成するオブジェクト(サブフォームなど)を検索できます。
「..」(2 つのピリオド)構文は、resolveNode メソッドでは、Javascript と共に使用できます。
例Subform_Page..Subform2 という式は、(通常どおりに)ノード Subform_Page を検索し、Subform_Page の子孫 Subform2 を検出することを意味します。
上記のサンプルツリーを使用すると、
Subform_Page..TextField2
は、以下と等価です。
Subform_Page.Subform1[0].Subform3.TextField2[0]
これは、TextField2[0] が、FormCalc が検索で遭遇する最初の Subform1 ノードにあるからです。2 つ目の例として、
Subform_Page..Subform3[*]
は、4 つの TextField2 オブジェクトをすべて返します。
名称未設定オブジェクトを示すか、またはプロパティを指定します番号記号(#)表記は、参照構文で次のいずれかの項目を表します。
resolveNode メソッドでは、「*」(番号記号)構文を JavaScript と共に使用できます。
例次の参照構文は名称未設定のサブフォームにアクセスします。
xfa.form.form1.#subform
サブフォームに name という名称のフィールドも含まれている場合、次の参照構文はサブフォームの name プロパティにアクセスします。
xfa.form.form1.#subform.#name
オブジェクトのオカレンス値角括弧([ ])表記はオブジェクトのオカレンス値を表します。
アラビア語、ヘブライ語、タイ語およびベトナム語に特化したフォームでは、(右から左に表記する言語であっても)参照構文が常に右側にあります。
例オカレンス値の参照を作成するには、オブジェクト名の後ろに角括弧([ ])を置き、括弧内に以下のいずれかの値を入れます。
[ n ] の n は、0 から始まる、オカレンスの絶対インデックス番号です。オカレンス値が範囲外の場合は何も値を返しません。以下に例を示します。
xfa.form.form1.#subform.Quantity[3]
は、Quantity オブジェクトの 4 番目のオカレンスを参照します。
[ +/- n ] の n は、参照を作成するオブジェクトのオカレンスと相対的なオカレンスを示します。正の値を指定するとオカレンス値は大きくなり、負の値を指定するとオカレンス値は小さくなります。以下に例を示します。
xfa.form.form1.#subform.Quantity[+2]
この参照では、参照を作成するコンテナのオカレンス値よりもオカレンス値が 2 だけ大きい Quantity の値が出力されます。例えば、この参照を Quantity[2] オブジェクトに追加すると、参照は以下と同じになります。
xfa.template.Quantity[4]
計算されたインデックス番号が範囲外の場合は、エラーを返します。
この構文は、特定のオブジェクトの前または次のオカレンスを検索するときに最も一般的に使用します。例えば、Quantity オブジェクトのオカレンス(1 つ目は除く)はすべて、Quantity[-1] を利用して前の Quantity オブジェクトの値を得ます。
[*] はオブジェクトの複数のオカレンスを示します。名前が付いた最初のオブジェクトが検出され、そのオブジェクトの兄弟で同名のオブジェクトが返されます。この表記法を使用すると、オブジェクトのコレクションが返されます。以下に例を示します。
xfa.form.form1.#subform.Quantity[*]
この式は、参照で検出された最初の Quantity の兄弟で、Quantity という名前を持つすべてのオブジェクトを参照します。
上記のツリーを参照した場合、以下の式が返すオブジェクトはそれぞれ次のとおりです。
Subform_Page.Subform1[*] は両方の Subform1 オブジェクトを返します。
Subform_Page.Subform1.Subform3.TextField2[*] は、2 つの TextField2 オブジェクトを返します。Subform_Page.Subform1 は左側の最初の Subform1 オブジェクトに解決され、TextField2[*] は Subform3 オブジェクトを基準にして評価されます。
Subform_Page.Subform1[*].TextField1 は両方の TextField1 インスタンスを返します。Subform_Page.Subform1[*] は両方の Subform1 オブジェクトに解決され、TextField1 は、Subform1 オブジェクトを基準にして評価されます。
Subform_Page.Subform1[*].Subform3.TextField2[1]returns the second and fourthTextField2objects from the left.Subform_Page.Subform1[*] は両方の Subform1 オブジェクトに解決され、TextField2[1] は Subform3 オブジェクトを基準にして評価されます。
Subform_Page.Subform1[*].Subform3[*] は両方の Subform3 オブジェクトのインスタンスを返します。
Subform_Page.* は Subform1 オブジェクトおよび Subform2 オブジェクトを返します。
Subform_Page.Subform2.* は NumericField2 オブジェクトの 2 つのインスタンスを返します。
「[ ]」(角括弧)構文は、resolveNode メソッドでは、JavaScript と共に使用できます。
|
|
|