On this Page

    _document

    This is the Document Object Model (DOM) object for the current document being processed. It enables access to field data and form field attributes. It contains a hierarchy that reflects the design's nested structure of Pages, Containers, Panes and Groups with their Fields and Text Labels, and it also reflects the various instances of those objects created as a result of merging data into the form design. For example:

    _document.main_pane.header_pane.customer_name._value

    The DOM is specific to the current combination of form design and data, and it reflects the current design's structure. _document reflects the top-level object in the document, i.e. the Form object.

    Optional and Multiple Panes

    One thing to be careful of is that if a Pane is optional and the data stream does not force its instantiation, then a reference to that Pane or to objects within that Pane will result in a runtime error. When scripting, you should keep the possibility of 'non-existence' of Panes in mind. See domObj.DOM and domObj.DOMValue

    Another thing is that you will have multiple instances of the same Pane and in those cases you must take care to specify which occurrence you wish to reference. Remember that when pagination occurs (and for all events after that), there is an even greater likelihood of multiple occurrences of Panes, even ones not marked as being Allow Multiple. This occurs because page headers and footers may have been injected multiple times. Multiple instances of a Pane can also occur if it had to be split across pages. In that case, the Pane object will exist in the DOM on both (or more) pages, with a part of the Pane on each page. Typical error messages in such cases are ScriptExtendedSyntax and DJ-GetResolveValName.

    Use of this._parent, this._ancestor() and this._descendant() can relieve a lot of the "have to know the occurrence number" headaches. Another technique is to stuff a value of interest, using a local reference, like this._value, into an _cache variable and then later referencing that _cache variable.

    The following script can help you understand the current document structure:

    for (var o=_document; o; o=o._nextNode) {
    	if (pn._type == "Pane") _logf("%s\n", o._fullName);
    }

    Note that the results of that will not be the same at all events so be sure to explore the document structure in the event where you are puzzling out an issue.

    Object Names with Colons

    Design and Merge allow us to define object names with a colon in them. This is useful to match XML that uses namespace prefixes. However, with JavaScript we cannot use a dotted SOM notation that has colons in it. If your form contains an object with a name that includes a colon (like "Colon:test"), you can't use dotted notation, such as _document.Colon:test. Instead, you should use square brackets around the object. For example:

    _document["Colon:test"].

    Or, you can use the DOMValue() or DOM() functions. For example:

    _document.DOMValue("Colon:test") 
    
    _document.DOM("Colon:test")

    Dom Object Attributes

    Fields and Text Labels have values and attributes (font, color, margins, and so on) which can be accessed and modified in script by specifying the name of the Field or Label followed by a dot followed by the attribute name. The value of the Field or Label is accessed as just another attribute named _value. The DOM properties topic (See DOM Properties) identifies the many, many properties that are available for reference. In that list the attributes are marked as return or set. return indicates that the attribute value may be accessed from script, while set indicates that it may be modified using script. There are versions of these attributes which do not have the leading underscore(_) in their names. However, the use of the leading underscore is highly recommended so as to avoid potential conflict with the object names in a document.

    Other DOMs

    See also the _page DOM. It is rarely used and reflects only a page subset of the overall _document DOM. 

    Note that the _data DOM is a completely different DOM, reflecting the XML data that is applied to the form design.