Aller au contenu principal
Version: Next

Propriétés des formulaires


Schéma de couleurs

La propriété de schéma de couleurs n'est appliquée que sur macOS.

Cette propriété définit la palette de couleurs du formulaire. Cette propriété définit la palette de couleurs du formulaire. Pour le formulaire, cette option peut être remplacée par l'une des deux options suivantes :

  • dark - texte clair sur fond foncé
  • light - texte foncé sur fond clair

Une palette de couleurs définie ne peut pas être remplacée par un CSS.

Grammaire JSON

NomType de donnéesValeurs possibles
colorSchemestring"dark", "light"

CSS

Cette propriété vous permet de charger le(s) fichier(s) CSS spécifiques pour le formulaire.

Un fichier CSS défini au niveau du formulaire remplacera la ou les feuilles de style par défaut. For more information, please refer to Style sheets page.

Grammaire JSON

NomType de donnéesValeurs possibles
cssstring ou collectionCSS file path(s) provided as:
  • a string (a file for both platforms)
  • a collection of strings (a list of files for both platform)
  • a collection of {"path":string;"media":"mac" | "win"} objects

  • Form Class

    Name of an existing user class to associate to the form . The user class can belong to the host project or to a component, in which case the formal syntax is "componentNameSpace.className".

    Associating a class to the form provides the following benefits:

    • When you work in the Form editor, the associated class is used for accurate syntax checking of expressions such as Form.myProperty in all areas of the Property list that support expressions (e.g. Variable or Expression, Font color expression...). Errors are displayed in red and warnings are displayed in yellow in the left column of the Property list and you can hover it to get explanations:

    • The detection of errors in the code of form object expressions by the compiler is improved.

    • You can also to benefit from autocompletion features in the code editor.

    • When the form is executed, 4D automatically instantiates a user class object for the form, which is returned by the Form object. Your code can directly access class functions defined in the user class through the Form command (e.g. Form.message()) without having to pass a formData object as parameter to the DIALOG, Print form, or FORM LOAD commands.

    note

    See this blog post for an illustration of this feature.

    Grammaire JSON

    NomType de donnéesValeurs possibles
    formClassstringname of an existing user class ("className" or "componentNameSpace.className")

    Nom du formulaire

    Cette propriété est le nom du formulaire lui-même et est utilisée pour faire référence au formulaire par son nom dans le langage 4D. The form name must comply with the rules specified for identifiers in 4D.

    Grammaire JSON

    Le nom du formulaire est défini par le nom du dossier qui contient le fichier form.4Dform. See project architecture for more information.


    Type de formulaire

    The form type, i.e. its destination, defines the features that will be available to the form. For example, markers can only be set for list (output) table forms.

    Chaque table dans une base de données a généralement au moins deux formulaires table. Un pour lister les enregistrements à l'écran et l'autre pour afficher un enregistrement à la fois (utilisé pour la saisie et les modifications) :

    • Output form - the output form or list form displays a list of records, with a single line per record. Les résultats des recherches sont affichés dans un formulaire de sortie et les utilisateurs peuvent double-cliquer sur une ligne pour afficher le formulaire d'entrée pour cet enregistrement.

    • Formulaire d'entrée ou formulaire détail - utilisé pour la saisie des données. It displays a single record per screen and typically has buttons for saving and canceling modifications to the record and for navigating from record to record (i.e., First Record, Last Record, Previous Record, Next Record).

    Les types pris en charge dépendent de la catégorie de formulaire :

    Type de formulaireGrammaire JSONDescriptionPrise en charge avec
    Formulaire de détaildetailScreenUn formulaire d'affichage pour la saisie et la modification des donnéesFormulaires projet - Formulaires table
    Formulaire de détail pour l'impressiondetailPrinterUn rapport imprimé avec une page par enregistrement, comme une factureFormulaires projet - Formulaires table
    Formulaire de listelistScreenUn formulaire pour lister les enregistrements à l'écranFormulaires table
    Formulaire de liste pour l'impressionlistPrinterUn rapport imprimé qui liste les enregistrementsFormulaires table
    Aucunno destinationUn formulaire sans fonction spécifiqueFormulaires projet - Formulaires table

    Grammaire JSON

    NomType de donnéesValeurs possibles
    destinationstring"detailScreen", "listScreen", "detailPrinter", "listPrinter"

    Nom du formulaire hérité

    This property designates the form to inherit in the current form.

    To inherit from a table form, set the table in the Inherited Form Table property.

    To remove inheritance, select \<None> in the Property List (or " " in JSON).

    Grammaire JSON

    NomType de donnéesValeurs possibles
    inheritedFormstringNom du formulaire table ou projet OU chemin POSIX d'un fichier .json décrivant le formulaire OU objet décrivant le formulaire

    Table du formulaire hérité

    This property specifies the database table from which to inherit a form in the current form.

    Set to \<None> in the Property List (or " " in JSON) to inherited from a project form.

    Grammaire JSON

    NomType de donnéesValeurs possibles
    inheritedFormTablestring ou numbernom ou numéro de table

    Pages

    Chaque formulaire est composé d'au moins deux pages :

    • une page 0 (page de fond)
    • une page 1 (page principale)

    Pour plus d'informations, veuillez consulter le thème Pages formulaire.

    Grammaire JSON

    NomType de donnéesValeurs possibles
    pagescollectionCollection de pages (chaque page est un objet, la page 0 est le premier élément)

    Publié en tant que sous-formulaire

    Pour qu'un formulaire de composant soit sélectionné comme sous-formulaire dans une base de données hôte, il doit avoir été explicitement partagé. Lorsque cette propriété est sélectionnée, le formulaire sera publié dans le projet hôte.

    Seuls les projets formulaire peuvent être indiqués comme étant des sous-formulaires publiés.

    Grammaire JSON

    NomType de donnéesValeurs possibles
    sharedbooleantrue, false

    Mémoriser géométrie

    Lorsque cette option est cochée, si la fenêtre est ouverte via la commande Creer fenetre formulaire avec le paramètre *, plusieurs paramètres du formulaire seront automatiquement mémorisés par 4D au moment de la fermeture de la fenêtre, quelle que soi

    • la page courante,
    • la position, la taille et la visibilité de chaque objet du formulaire (y compris la taille et la visibilité des colonnes de list box).

    Cette option ne prend pas en compte les objets générés via la commande OBJECT DUPLICATE. Pour que l’utilisateur retrouve son environnement lors de l’utilisation de cette commande, le développeur doit répéter la séquence de création, définition et positionnement des objets.

    Lorsque cette option est cochée, l’option Mémoriser valeur est en outre disponible pour certains objets.

    Grammaire JSON

    NomType de donnéesValeurs possibles
    memorizeGeometrybooleantrue, false

    Voir également

    Save Value


    Nom de la fenêtre

    Le nom de la fenêtre est utilisé lorsque le formulaire est ouvert à l'aide des commandes Open form window et Open window dans l'environnement d'application. Le nom de la fenêtre apparaît dans la barre de titre de la fenêtre.

    Vous pouvez utiliser des références dynamiques pour définir les noms de fenêtre des formulaires, c'est-à-dire :

    • Une référence XLIFF standard stockée dans le dossier Resources.
    • Un libellé de table ou de champ : La syntaxe à appliquer est la suivante : <?[TableNum]FieldNum> ou <?[TableName]FieldName>.
    • Une variable ou un champ : La syntaxe à appliquer est la suivante : \N-<VariableName&#062 ; ou &#060 ;[TableName]FieldName&#062 ;. La valeur du champ ou de la variable sera affichée dans le nom de la fenêtre.

    Le nombre de caractères pour un nom de fenêtre est limité à 31.

    Grammaire JSON

    NomType de donnéesValeurs possibles
    windowTitlestringLe nom de la fenêtre sous forme de texte brut ou de référence