4D v16.3

LISTBOX INSERER COLONNE

Accueil

 
4D v16.3
LISTBOX INSERER COLONNE

LISTBOX INSERER COLONNE 


 

LISTBOX INSERER COLONNE ( {* ;} objet ; positionCol ; nomCol ; variableCol ; nomEnTête ; variableEntête {; nomPied ; variablePied} )  
Paramètre Type   Description
Opérateur in Si spécifié, objet est un nom d’objet (chaîne) Si omis, objet est une variable
objet  Objet de formulaire in Nom d’objet (si * est spécifié) ou Variable (si * est omis)
positionCol  Entier long in Emplacement de la colonne à insérer
nomCol  Chaîne in Nom d’objet de la colonne
variableCol  Tableau, Champ, Variable, Pointeur nil in Nom de la variable tableau de la colonne ou champ ou variable
nomEnTête  Chaîne in Nom d’objet de l’en-tête de la colonne
variableEntête  Variable entier, Pointeur nil in Variable d’en-tête de la colonne
nomPied  Chaîne in Nom d’objet du pied de la colonne
variablePied  Variable, Pointeur nil in Variable du pied de la colonne

La commande LISTBOX INSERER COLONNE insère une colonne dans la list box désignée par les paramètres objet et *

Note : Cette commande ne fait rien si elle est appliquée à la première colonne d’une list box affichée en mode hiérarchique.

Si vous passez le paramètre optionnel *, vous indiquez que le paramètre objet est un nom d’objet (une chaîne). Si vous ne passez pas ce paramètre, vous indiquez que le paramètre objet est une variable. Dans ce cas, vous ne passez pas une chaîne mais une référence de variable. Pour plus d'informations sur les noms d’objets, reportez-vous à la section Objets de formulaires.

La nouvelle colonne est insérée juste avant la colonne désignée par le paramètre positionCol. Si le paramètre positionCol est supérieur au nombre total de colonnes, la colonne est ajoutée après la dernière colonne.

Passez dans les paramètres nomCol et variableCol le nom d’objet et la variable de la colonne insérée.

  • Dans le cadre d'une list box de type tableau, le nom de la variable correspond au nom du tableau dont le contenu sera affiché dans la colonne. Vous pouvez passer un pointeur Nil (->[]) si vous utilisez la commande dans un contexte dynamique à l'exécution du formulaire (cf. ci-dessous).
  • Dans le cadre d'une list box de type sélection, vous pouvez passer un champ ou une variable dans le paramètre variableCol. Le contenu de la colonne sera alors la valeur du champ ou de la variable, évaluée pour chaque enregistrement de la sélection associée à la list box. Ce type de contenu ne peut être utilisé que lorsque la propriété “Source de données” de la list box est Sélection courante ou Sélection temporaire (cf. section Gestion programmée des objets de type List box). Vous pouvez utiliser des champs ou des variables de type chaîne, numérique, Date, Heure, Image et Booléen.

Dans le contexte de list box basées sur des sélections, LISTBOX INSERER COLONNE permet d’insérer des éléments simples (champs ou variables). Si vous souhaitez manipuler des expressions plus complexes (telles que des formules ou des méthodes), vous devez utiliser la commande LISTBOX INSERER COLONNE FORMULE.

Note : Il n’est pas possible de combiner dans une même list box des colonnes de type tableau (source de données tableaux) et des colonnes de type champ ou variable (source de données sélection).

Passez dans les paramètres nomEntête et variableEntête le nom d’objet et la variable de l’en-tête de la colonne insérée.

Vous pouvez également passer dans les paramètres nomPied et variablePied le nom d’objet et la variable du pied de la colonne insérée.

Note : Les noms d’objets doivent être uniques dans un formulaire. Vous devez veiller à ce que les noms passés dans les paramètres nomCol, nomEntête et nomPied ne soient pas déjà utilisés. Sinon, la colonne n’est pas créée et une erreur est générée.

A compter de 4D v14 R3, vous pouvez utiliser cette commande pour insérer dynamiquement des colonnes dans les list box à l'exécution du formulaire, 4D prenant automatiquement en charge les définitions de variables nécessaires (colonne, pied et en-tête).

Pour cela, LISTBOX INSERER COLONNE accepte un pointeur Nil (->[]) comme valeur pour les paramètres variableCol (list box de type tableau uniquement), variableEntête et variablePied. Dans ce cas, 4D va créer dynamiquement les variables requises lors de l'exécution de la commande (pour plus d'informations, reportez-vous à la section Variables dynamiques). 

A noter que les variables d'en-tête et de pied sont toujours créées avec un type spécifique (respectivement entier long et texte). A l'inverse, les variables de colonne ne peuvent pas être typées à la création car les list box acceptent différents types de tableaux pour ces variables (tableau texte, tableau entier, etc.). Vous devez donc définir manuellement le type du tableau (cf. exemple 3). Il est important d'effectuer ce typage avant d'appeler des commandes telles que LISTBOX INSERER LIGNES pour insérer des nouveaux éléments dans le tableau. Ou bien, il est possible d'utiliser AJOUTER A TABLEAU pour à la fois typer le tableau et insérer des éléments. 

Nous souhaitons ajouter une colonne à la fin de la list box :

 C_ENTIER LONG(NomVarHeader;$Der;$NbEnr)
 TOUT SELECTIONNER([Table 1])
 $NbEnr:=Enregistrements dans table([Table 1])
 TABLEAU IMAGE(tabImage;$NbEnr)
 
 $Der:=LISTBOX Lire nombre colonnes(*;"ListBox1")+1
 LISTBOX INSERER COLONNE(*;"ListBox1";$Der;"ColumnPicture";tabImage;"HeaderPicture";NomVarHeader)

Nous souhaitons ajouter une colonne à la droite de la list box et lui associer les valeurs du champ [Envois]Frais :

 $der:=LISTBOX Lire nombre colonnes(*;"ListBox1")+1
 LISTBOX INSERER COLONNE(*;"ListBox1";$der;"ColChamp";[Envois]Frais;"NomEntete";VarEntete)

Vous souhaitez insérer dynamiquement une colonne dans une list box de type tableau et définir son en-tête :

 C_POINTEUR($NilPtr)
 LISTBOX INSERER COLONNE(*;"MyListBox";1;"MyNewColumn";$NilPtr;"MyNewHeader";$NilPtr)
 ColPtr:=OBJET Lire pointeur(Objet nommé;"MyNewColumn")
 TABLEAU TEXTE(ColPtr->;10)
     //Définition de l'en-tête
 headprt:=OBJET Lire pointeur(Objet nommé;"MyNewHeader")
 OBJET FIXER TITRE(headprt->;"Entête inséré")



Voir aussi  

LISTBOX INSERER COLONNE FORMULE
LISTBOX SUPPRIMER COLONNE

 
PROPRIÉTÉS 

Produit : 4D
Thème : List Box
Numéro : 829
Nom intl. : LISTBOX INSERT COLUMN

 
HISTORIQUE 

Modifié : 4D v11 SQL
Renommé : 4D v12
Modifié : 4D v13
Modifié : 4D v14 R3

 
UTILISATION DE L'ARTICLE

4D - Langage ( 4D v16)
4D - Langage ( 4D v16.1)
4D - Langage ( 4D v16.2)
4D - Langage ( 4D v16.3)