Résoudre les problèmes de formulaire dans les applications pilotées par modèle
Cet article vous aide à résoudre certains problèmes courants qui surviennent lors de l’utilisation des formulaires des applications pilotées par modèle.
Important
- Les outils décrits dans cet article sont conçus pour la résolution des problèmes. Ils ne sont pas destinés à être utilisés dans des scénarios de production quotidiens même s’ils peuvent servir à résoudre des problèmes dans des environnements de production.
- Ces solutions n’affectent que la session utilisateur actuelle, sauf indication contraire (par exemple, si un onglet du navigateur accède à l’application pilotée par modèle). Elles ne modifient pas les personnalisations du système et n’affectent aucun autre utilisateur ou session. Une fois la session en cours fermée, l’effet n’est plus appliqué.
- La plupart des outils sont disponibles dans tous les environnements de production. Certains d’entre eux, mentionnés dans l’article, n’ont peut-être pas encore été déployées dans votre organisation. De nouveaux outils sont ajoutés périodiquement.
- Les outils répertoriés dans cet article sont écrits selon un scénario. Vous pouvez les utiliser indépendamment pour résoudre différents types de problèmes.
- Utiliser les paramètres d’URL pour désactiver divers composants de formulaire et Afficher les gestionnaires d’événements et les bibliothèques de formulaires enregistrés dans Moniteur sont des outils essentiels et fondamentaux qui serviront fréquemment pour solutionner de nombreux scénarios.
- Pour plus d’informations sur l’utilisation de Monitor, consultez Utiliser Monitor pour résoudre les problèmes de comportement du formulaire des applications pilotées par modèle
Utiliser les paramètres d’URL pour désactiver divers composants de formulaire
Si vous résolvez des problèmes avec les formulaires, vous devez utiliser les paramètres d’URL pour désactiver les composants lorsque vous cherchez à isoler le composant spécifique à l’origine du problème. Nous vous recommandons d’utiliser les indicateurs un par un pour affiner la cause du problème. Vous pouvez utiliser les paramètres URL suivants :
DisableFormCommandbar
Désactive la barre de commandes sur le formulaire. Il désactive uniquement la barre de commandes sur les pages de formulaire et ne prend pas en charge la liste (grille), le tableau de bord, etc.
https://myorg.crm.dynamics.crm/main.aspx?appid=00000000-0000-0000-0000-000000000000&pagetype=entityrecord&id=00000000-0000-0000-0000-000000000000**&flags=DisableFormCommandbar=true
DisableFormHandlers
Désactive tous les gestionnaires de formulaires. Si vous utilisez l’indicateur DisableFormHandlers=true, cela désactive les gestionnaires d’événement suivants : OnLoad, OnSave, business rule, OnChange et TabStateChange.
Pour en savoir plus sur l’obtention des index d’événements ou de bibliothèques pour les contrôles granulaires, voir Afficher les gestionnaires d’événements et les bibliothèques de formulaires enregistrés dans Moniteur.
https://myorg.crm.dynamics.crm/main.aspx?appid=00000000-0000-0000-0000-000000000000&pagetype=entityrecord&id=00000000-0000-0000-0000-000000000000**&flags=DisableFormHandlers=true
&flags=DisableFormHandlers=eventName
Désactive le gestionnaire de formulaires en spécifiant le nom de l’événement, par exemple, **DisableFormHandlers=onload.
https://myorg.crm.dynamics.crm/main.aspx?appid=00000000-0000-0000-0000-000000000000&pagetype=entityrecord&id=00000000-0000-0000-0000-000000000000**&flags=DisableFormHandlers=true
&flags=DisableFormHandlers=eventName_index
Désactive le gestionnaire d’événements à l’index spécifié pour tout nom d’événement pris en charge. Par exemple,
DisableFormHandlers=true_0
désactive tous les gestionnaires d’événements à l’index 0.DisableFormHandlers=onload_2
désactive le gestionnaire d’événements OnLoad à l’index 2.&flags=DisableFormHandlers=eventName_startIndex_endIndex
Désactive tous les gestionnaires d’événements dans la plage donnée en spécifiant les valeurs
startIndex
etendIndex
(incluses toutes les deux). Par exemple,DisableFormHandlers=true_0_2
désactive tous les gestionnaires d’événements aux index 0, 1 et 2.DisableFormHandlers=onload_2_5
désactive le gestionnaire d’événements OnLoad aux index 2, 3, 4 et 5. Si vous avez plus de gestionnaires d’événements, vous pouvez utiliser cette approche pour affiner rapidement les gestionnaires problématiques.
Note
Les règles métier sont créées dans le concepteur de règles métier, compilées dans le script côté client et enregistrées dans plusieurs événements de formulaire, tels que
OnLoad
,OnSave
etOnChange
. La façon de désactiver les règles métier est très similaire aux autres événements de formulaire. Cependant, des différences clés existent :- Si vous utilisez
DisableFormHandlers=true
,businessrule
,businessrule_*index*
oubusinessrule_*startIndex_endIndex*
, vous désactivez la ou les règles métier dans tous les événements de formulaire dans lesquels elles sont enregistrées. - Par exemple, l’image ci-dessous montre des instructions sur l’actualisation de la ou des règles métier dans le serveur principal. Vous n’avez besoin de le faire qu’une seule fois dans l’organisation et pouvez annuler vos modifications après la résolution des problèmes.
- Après avoir effectué l’action ci-dessus et actualisé le formulaire, vous affichez un message différent avec des informations supplémentaires, comme dans l’image ci-dessous :
DisableFormLibraries
Désactive les bibliothèques de formulaires et empêche leur chargement. Pour en savoir plus sur l’obtention des index d’événements ou de bibliothèques pour les contrôles granulaires, voir Afficher les gestionnaires d’événements et les bibliothèques de formulaires enregistrés dans Moniteur. L’utilisation est similaire au paramètre
DisableFormHandlers
à la différence qu’il ne prend pas de nom d’événement comme valeur.- &flags=DisableFormLibraries=true : désactive toutes les bibliothèques de formulaires.
- &flags=DisableFormLibraries=index : désactive les bibliothèques de formulaires à l’index spécifié.
- &flags=DisableFormLibraries=startIndex_endIndex : désactive les bibliothèques de formulaires dans la plage startIndex et endIndex (tous deux inclus).
DisableWebResourceControls
Désactive tous les contrôles de ressources Web sur le formulaire.
https://myorg.crm.dynamics.crm/main.aspx?appid=00000000-0000-0000-0000-000000000000&pagetype=entityrecord&id=00000000-0000-0000-0000-000000000000**&flags=DisableWebResourceControls=true
DisableFormControl
Désactive un contrôles de formulaire. Spécifiez le nom du contrôle pour désactiver le contrôle. Si vous voyez que le problème disparaît avec &flags=DisableWebResourceControls=true et qu’il existe plusieurs contrôles de ressources Web sur le formulaire, utilisez cet indicateur pour identifier davantage le contrôle à l’origine du problème.
https://myorg.crm.dynamics.crm/main.aspx?appid=00000000-0000-0000-0000-000000000000&pagetype=entityrecord&id=00000000-0000-0000-0000-000000000000**&flags=DisableFormControl=controlname
DisableBusinessProcessFlow
Désactive tous les flux des processus d’entreprise sur le formulaire.
https://myorg.crm.dynamics.crm/main.aspx?appid=00000000-0000-0000-0000-000000000000&pagetype=entityrecord&id=00000000-0000-0000-0000-000000000000**&flags=DisableBusinessProcessFlow=true
navbar n’est pas un paramètre indicateur ; à la place, utilisez navbar=off dans l’URL.
Vous pouvez également ajouter plusieurs paramètres d’URL séparés par une virgule (,).
https://myorg.crm.dynamics.crm/main.aspx?appid=00000000-0000-0000-0000-000000000000&pagetype=entityrecord&id=00000000-0000-0000-0000-000000000000**&flags=DisableFormHandlers=true,DisableWebResourceControls=true,DisableFormCommandbar=true,DisableBusinessProcessFlow=true&navbar=off
Note
Les différences entre DisableFormHandlers et DisableFormLibraries sont les suivantes :
- L’indicateur DisableFormHandlers désactive les gestionnaires de formulaires quelles que soient les bibliothèques de formulaires qui les contiennent. En revanche, l’indicateur DisableFormLibraries désactive les bibliothèques de formulaires (ressources Web) quelles que soient les fonctions (gestionnaires d’événements) incluses dans les bibliothèques. Pour faire simple, DisableFormLibraries s’assure que les fichiers de ressources Web JavaScript spécifiés ne sont pas chargés.
- L’indicateur DisableFormHandlers n’empêche pas le chargement de la bibliothèque de formulaires contenante. Ainsi, cela n’arrête pas l’exécution du code JavaScript présent dans la bibliothèque mais non enregistré en tant que gestionnaire d’événements. Par exemple, si une bibliothèque de formulaires
new_myscript.js
est écrite de la manière suivante (non conseillée) : - Commencez avec l’indicateur DisableFormHandlers pour voir si le problème disparaît, et si ce n’est pas le cas, essayez l’indicateur DisableFormLibraries. La désactivation d’un script implique toujours des risques de rupture potentielle des scénarios de formulaire. Cependant, ces derniers ont tendance à avoir plus d’effets secondaires à cause de la désactivation de l’ensemble des fichiers JavaScript.
- En supposant que le paramètre
myOnloadHandler
est enregistré en tant que gestionnaire d’événementsOnLoad
, l’indicateurDisableFormHandlers=true
n’empêche que la deuxième alerte alors que l’indicateurDisableFormLibraries=true
empêche les deux alertes.
Afficher les gestionnaires d’événements et les bibliothèques de formulaires enregistrés dans Moniteur
Pour afficher les descripteurs et bibliothèques d’événements de formulaires enregistrés, vous pouvez afficher l’opération FormEvents
dans Moniteur.
Vous aurez besoin des valeurs de paramètre eventIndex
et libraryIndex
lors de l’utilisation des indicateurs d’URL DisableFormHandlers ou DisableFormLibraries. Après la désactivation d’un événement ou d’une bibliothèque, vous verrrez l’état activé de l’événement à la fois dans l’opération FormEvents (vue globale de tous les gestionnaires d’événements enregistrés de tous les événements) et dans l’opération FormEvents.eventName (informations consignées lorsqu’un événement spécifique se produit).
Comportements inattendus lors du chargement d’un formulaire
Parmi certains problèmes courants qui peuvent provoquer un comportement inattendu lors du chargement d’un formulaire d’application pilotée par modèle figurent les suivants :
- Les colonnes ou les contrôles n’ont pas les valeurs attendues.
- Les contrôles ne sont pas désactivés ou ne sont pas activés.
- Les contrôles ne sont pas affichés ou ne sont pas masqués.
Procédure de résolution des problèmes
Il existe plusieurs raisons pour lesquelles des comportements inattendus se produisent lors de l’ouverture d’un formulaire. Les plus courants sont les scripts OnLoad qui s’exécutent de manière synchrone ou asynchrone pour modifier la colonne ou contrôler le comportement. Pour déterminer si votre script est à l’origine du problème, vous pouvez désactiver les gestionnaires de formulaire en ajoutant &flags=DisableFormHandlers=true à la fin de votre URL d’application.
Si le comportement inattendu cesse de se produire après avoir désactivé le gestionnaire de formulaires, cela indique clairement que le gestionnaire de formulaires spécifique est à l’origine de ce comportement. Si vous avez identifié le script à l’origine du comportement, suivez avec le propriétaire du script pour solutionner davantage ce problème.
Message d’erreur Enregistrement en cours
Parfois, lorsque vous enregistrez un formulaire, vous voyez un message d’erreur Enregistrement en cours.
Cette erreur se produit lorsque l’événement de formulaire OnSave est déclenché avant la fin du précédent événement OnSave. Ce comportement n’est pas pris en charge et l’erreur apparaît de par sa conception, car l’appel de l’événement OnSave
avant la fin du précédent événement OnSave
provoque des boucles de sauvegarde récursives avec des conséquences inattendues.
Une cause typique de cette erreur est le script qui appelle la méthode save()
dans le gestionnaire d’événements OnSave. Une autre cause possible pourrait être des appels save()
concomitants dans la méthode setTimeout()
, ce qui peut provoquer l’apparition de l’erreur par intermittence, selon que l’appel save()
précédent a été terminé avant un autre save()
.
Procédure de résolution des problèmes
Dans Moniteur, l’opération FormEvents.onsave
fournit tous les détails à l’origine de l’erreur (la pile d’appels a été modifiée à des fins de démonstration). La pile d’appels indique la ressource Web, la fonction, la ligne et le numéro de ligne exacts à l’origine de cette erreur. Le vérificateur de formulaire ne parvient pas à détecter l’erreur si le problème ne peut pas être reproduit.
Suivez avec le propriétaire du script pour solutionner davantage le problème.
Erreurs de formulaire intermittentes
La cause la plus fréquente d’erreurs de formulaire intermittentes ou aléatoires est l’utilisation de méthodes API client non prises en charge. Ces erreurs ont les caractéristiques suivantes :
- Elles se produisent uniquement pour des enregistrements, utilisateurs, régions ou navigateurs spécifiques, ou uniquement pendant des périodes où la charge du réseau ou du service est élevée.
- Elles se produisent rarement dans les instances de support.
- Elles peuvent se produire une fois sur un ordinateur et la même erreur peut se reproduire après avoir vidé le cache du navigateur.
- formContext.getControl ou alors formContext.getControl(arg).getAttribute() renvoie aléatoirement null pour un contrôle ou une colonne valide.
Il existe de nombreuses façons d’écrire des méthodes API client non prises en charge et elles partagent toutes un modèle commun : elles provoquent une condition de concurrence dans le pipeline de chargement du formulaire. Dans la mesure où il introduit une condition de concurrence, le problème se produit uniquement si le script personnalisé s’exécute avant que le formulaire ne soit entièrement prêt à être accessible via l’API client. De nombreux facteurs peuvent provoquer une situation de concurrence critique :
Dans la ressource Web JavaScript, le code est placé dans une portée globale qui est exécutée immédiatement lorsque le fichier de ressource Web est chargé, sans attendre que le formulaire soit accessible. Veillez à ce que le code soit exécuté dans un gestionnaire de formulaires valide, tel qu’un gestionnaire OnLoad.
Dans le fichier de script de composants Power Apps component framework, les méthodes API client sont accessibles dans la fonction init ou updateView. Les fonctions
init()
etupdateView()
sont exécutées immédiatement lorsque le composant est chargé, sans avoir à attendre que le formulaire soit facilement accessible. Vous ne pouvez pas utiliser de méthodes d’API client non prises en charge dans les composants de Power Apps component framework.
L’API client est accessible dans une fonction window.setTimeout()
dans le fichier de ressource Web. L’état de la page est imprévisible si la méthode setTimeout()
exécute la fonction encapsulée. Du fait de la nature de la fonction de minuterie, si l’exécution se produit, la page pourrait être dans un état transitionnel (pendant le chargement ou l’enregistrement de la page) qui n’est pas facilement accessible par l’API client.
Procédure de résolution des problèmes
En utilisant Moniteur, vous pouvez accéder aux informations qui vous aident à déterminer quand l’accès client non pris en charge s’est produit et quand l’accès s’est produit au mauvais moment en raison d’une condition de concurrence. Cependant, le vérificateur de formulaire ne signale pas un accès client non pris en charge si le code non pris en charge s’exécute au bon moment, ce qui ne pose pas de problème.
Note
La pile d’appels a été modifiée à des fins d’illustration. La pile d’appels affiche des détails tels que la ressource Web, la fonction et la ligne à l’origine de l’erreur.
Suivez avec le propriétaire du script pour solutionner davantage le problème.
Le formulaire ou l’enregistrement n’est pas enregistré lorsque vous essayez d’enregistrer le formulaire
Une cause commune est un gestionnaire d’événements OnSave qui appelle la méthode executionContext.getEventArgs().preventDefault() pour annuler l’opération d’enregistrement.
Procédure de résolution des problèmes
Dans Moniteur, l’opération FormEvents.onsave
fournit tous les détails sur la raison pour laquelle l’événement d’enregistrement est annulé, plus de détails que ceux disponibles à partir de l’interface utilisateur du formulaire elle-même.
Suivez avec le propriétaire du script pour solutionner davantage le problème.
Le formulaire se fige, se charge lentement ou génère des erreurs inexpliquées
Il existe de nombreuses raisons possibles pour qu’un formulaire se fige, se charge lentement ou génère une erreur de script « La méthode de ressource Web n’existe pas » ou une erreur qui n’est pas une erreur de script commune. Certaines des raisons possibles sont les suivantes :
- Scripts
OnLoad
inappropriés. - Contrôles de ressource Web.
- Scripts et règles du bouton du ruban.
- Requêtes réseau synchrones.
- Plug-ins personnalisés.
- Erreurs de flux des processus d’entreprise.
Procédure de résolution des problèmes
Déterminez si le problème se reproduit sans impliquer les formulaires. Si c’est le cas, le problème est donc plus large et il doit être étudié hors du contexte du formulaire. La propriété réelle du problème dépend des détails particuliers au cas par cas.
- Si vous pensez que ce problème ne se produit que sur les formulaires, voir Utiliser les paramètres d’URL pour désactiver divers composants de formulaire pour affiner le composant à l’origine du problème.
- Si vous avez identifié que le problème est causé par certain(e)s bibliothèques de formulaires/fichiers de script, suivez avec le propriétaire qui a effectué ces personnalisations pour découvrir la cause racine du problème.
- Si vous avez identifié que les contrôles de ressource Web causent le problème avec l’indicateur DisableWebResourceControls, utilisez l’indicateur
DisableFormControl
pour désactiver chacun un par un jusqu’à ce que le problème ne se reproduise plus. Le dernier contrôle désactivé qui ne reproduit pas le problème est celui à l’origine du problème. Suivez avec le propriétaire du contrôle pour solutionner davantage le problème. - Si vous avez identifié que le problème est causé par la barre de commandes/le ruban avec l’indicateur DisableFormCommandbar, cela signifie que le formulaire n’est pas en cause mais qu’il y a un problème avec la barre de commandes. Utilisez le vérificateur de commandes pour résoudre les problèmes au niveau de chaque commande et identifier la commande à l’origine du problème.
Une règle métier ou un script personnalisé ne fonctionne pas
Ce problème se produit si une règle métier ou un script personnalisé fonctionnait dans l’ancien client Web mais à cessé de fonctionner dans Unified Interface. L’une des principales raisons pour lesquelles cette erreur se produit est lorsqu’une règle métier ou un script dans Unified Interface fait référence à un contrôle qui n’est pas disponible dans Unified Interface.
Procédure de résolution des problèmes
L’une des raisons pour lesquelles la règle métier ou le script ne fonctionnent pas dans Unified Interface est que les contrôles qui en font partie n’existent pas dans Unified Interface.
Les contrôles composites existent dans le client Web mais dans Unified Interface, le contrôle composite est divisé en plusieurs parties et stocké différemment. Par exemple, si la colonne fullname
fait partie de la règle métier ou du script personnalisé, les colonnes firstname
, middlename
ou lastname
doivent être utilisées à la place.
Une fois le vérificateur de formulaire lancé, vous pouvez afficher plus de détails dans l’opération CompositeControl
dont le contrôle composite est à l’origine du problème, les colonnes pouvant être utilisées dans la règle métier ou le script personnalisé à la place et une pile d’appels complète (la pile d’appels a été modifiée à des fins de démonstration).
Suivez avec le propriétaire correspondant de la règle métier ou du script personnalisé pour modifier le contrôle suggéré par le vérificateur de formulaire.
L’élément de menu associé n’apparaît pas dans l’onglet Associé
La plupart des formulaires comportent un onglet Associé. Il ouvre le Menu associé avec Éléments de menu associés.
Un Élément de menu associé peut ne pas apparaître comme prévu.
Procédure de résolution des problèmes
Un élément de menu associé peut ne pas apparaître pour les raisons suivantes :
La relation entre la table principale et la table associée n’est pas configurée correctement
Il doit exister une relation un-à-plusieurs ou plusieurs-à-plusieurs entre la table principale et la table associée. Un formulaire affiche une rangée de la table principale. La table associée est celle qui doit apparaître dans le menu Associé du formulaire. Si ces relations n’existent pas, l’élément de menu associé n’apparaît pas.
Pour vérifier, accédez au Portail Power Apps, sélectionnez Tables, et sélectionnez la table contenant les relations à afficher.
Dataverse a créé la relation entre la table principale et la table associée et elle n’est pas personnalisable
Le menu Associé n’affiche pas les tables associées de certains relations créés par Dataverse. Ces relations sont marqués comme non personnalisables.
La propriété AssociatedMenuConfiguration.IsCustomizing indique si la relation peut être personnalisée. Le moyen le plus simple de vérifier consiste à interroger la relation à l’aide de l’API web pour afficher les données de type complexe AssociatedMenuConfiguration .
Supposons que vous souhaitiez vérifier si la relation entre les tables Division et Objectif est personnalisable. Le SchemaName
de cette relation est business_unit_goal. Saisissez l’URL suivante dans votre navigateur :
GET [Organization URI]/api/data/v9.2/RelationshipDefinitions(SchemaName='business_unit_goal')/Microsoft.Dynamics.CRM.OneToManyRelationshipMetadata?$select=AssociatedMenuConfiguration
Vous pouvez également obtenir les mêmes données en interrogeant la définition de la table :
GET [Organization URI]/api/data/v9.2/EntityDefinitions(LogicalName='businessunit')/OneToManyRelationships(SchemaName='business_unit_goal')/AssociatedMenuConfiguration
La réponse à l’une ou l’autre requête pourrait ressembler à ceci :
{
"@odata.context": "[Organization URI]/api/data/v9.2/$metadata#RelationshipDefinitions/Microsoft.Dynamics.CRM.OneToManyRelationshipMetadata(AssociatedMenuConfiguration)/$entity",
"MetadataId": "2124b4bd-f013-df11-a16e-00155d7aa40d",
"AssociatedMenuConfiguration": {
"Behavior": "UseCollectionName",
"Group": "Details",
"Order": null,
"IsCustomizable": false,
"Icon": null,
"ViewId": "00000000-0000-0000-0000-000000000000",
"AvailableOffline": true,
"MenuId": null,
"QueryApi": null,
"Label": {
"LocalizedLabels": [],
"UserLocalizedLabel": null
}
}
}
Observez que IsCustomizable
est false
. Par conséquent, la relation n’est pas personnalisable et Objectif n’apparaît pas dans le menu Associé .
Table Associé non activée pour Unified Client
Si la table a été créée dans le client Web (obsolète depuis 2019), elle peut ne pas apparaître car elle est désactivée pour Unified Client.
Pour vérifier, accédez à Explorateur de solutions et sélectionnez la table (entité). Assurez-vous que Activer pour Unified Client est coché.
Les tables créées avec le concepteur moderne n’ont pas ce problème. Elles sont toujours activées pour Unified Client
Note
Certaines des tables système ne peuvent pas être activées pour Unified Client. Par exemple, Session de processus ne peut pas être utilisée dans les applications pilotées par modèle.
L’historique d’audit n’apparaît pas dans l’onglet Associé
Historique d’audit ne figure pas dans le menu Associé.
Procédure de résolution des problèmes
L’historique d’audit n’est pas pris en charge dans les cas suivants :
- Les tables ne sont pas activées pour l’audit. Vérifiez la propriété IsAuditEnabled de la table pour confirmer.
- Tables système qui ne prennent pas en charge l’historique d’audit
- Applications mobiles
- Mode hors connexion
- Dynamics pour Outlook
Un élément de menu associé inattendu apparaît dans l’onglet associé
Un Élément de menu associé peut apparaître alors qu’il ne devrait pas.
Procédure de résolution des problèmes
Un élément de menu associé peut apparaître pour les raisons suivantes :
La table associée a une relation plusieurs-à-plusieurs auto-référentielle avec la table principale
Le système ignore les personnalisations du formulaire XML pour les relations plusieurs-à-plusieurs auto-référentielles. Le système ignore ces personnalisations, car il n’est pas possible d’indiquer si les personnalisations concernent la table principale ou la table associée, qui sont tous les deux la même table dans ce cas. Par conséquent, le système ignore ces personnalisations.
Si vous modifiez le formulaire XML pour masquer l’élément de menu associé, il apparaît toujours. Toutes les personnalisations du formulaire XML pour les relations auto-référentielles sont ignorées, comme la modification de l’ordre ou de l’étiquette de l’élément associé.
Certaines tables système ne peuvent pas être masquées
Par exemple, les tables personnalisées affichent toujours l’élément de menu associé Activités. Il n’est pas possible de le masquer avec le concepteur de formulaires ou en modifiant le formulaire XML.
Les éléments de menu associés ne sont pas traduits comme prévu
Le texte des éléments de menu associés n’est pas dans la langue attendue.
Procédure de résolution des problèmes
Si certains éléments de menu associés s’affichent dans une langue différente de celle de l’utilisateur, vérifiez s’il manque des étiquettes traduites dans le formulaire XML.
Vérifiez le formulaire XML pour voir si des étiquettes sont définies pour chaque langue. Par exemple, ce formulaire XML indique que l’élément navContacts
n’a qu’une étiquette en anglais américain (1033) : Contacts
.
<NavBarByRelationshipItem Id="navContacts" Area="Sales" Sequence="10064" RelationshipName="contact_customer_accounts" Show="true">
<Titles>
<Title LCID="1033" Title="Contacts" />
</Titles>
</NavBarByRelationshipItem>
Pour résoudre ce problème, ajoutez les étiquettes traduites au formulaire XML. Par exemple, ce formulaire XML indique l’élément navContacts
avec des étiquettes en anglais américain (1033) et en allemand (1031).
<NavBarByRelationshipItem Id="navContacts" Area="Sales" Sequence="10064" RelationshipName="contact_customer_accounts" Show="true">
<Titles>
<Title LCID="1033" Title="Contacts" />
<Title LCID="1031" Title="Kontakte" />
</Titles>
</NavBarByRelationshipItem>
Si le texte pour la langue de l’utilisateur n’est pas défini, le système utilise la langue de base de l’organisation. Si elle n’existe pas non plus, le système utilise le texte en anglais américain.
Pourquoi un formulaire s’affiche-t-il ou non dans le sélecteur de formulaire ?
Le sélecteur de formulaire est une liste déroulante qui permet aux utilisateurs de basculer entre différents formulaires pour une table particulière.
Vous devez comprendre les conditions qui contrôlent l’affichage du formulaire.
Procédure de résolution des problèmes
Un formulaire est disponible dans le sélecteur lorsque toutes ces conditions sont remplies :
- L’utilisateur est autorisé à accéder au formulaire.
- Le formulaire est ajouté au module d’application.
- Le formulaire n’est pas masqué avec l’API client.
- Pour les formulaires Dynamics Customer Service workspace, ShowInFormSelector est défini sur True.
Si un formulaire n’apparaît pas dans le sélecteur de formulaire,
- Vérifiez les rôles de sécurité de l’utilisateur affecté.
- Vérifiez que le formulaire est ajouté au module d’application.
- Désactivz les scripts personnalisés
Pourquoi un formulaire par défaut attendu n’est-il pas affiché par défaut ?
Lorsqu’il existe plusieurs formulaires pour un tableau, celui souhaité n’est pas utilisé par défaut.
Procédure de résolution des problèmes
Les critères suivants déterminent le premier formulaire présenté à l’utilisateur :
- Si un formId est fourni lors de l’ouverture d’un formulaire, alors ce formulaire est affiché. Un formId peut être fourni via des fonctions de l’API client telles que openForm ou dans une URL.
- Sinon, le formulaire le plus récent sélectionné par l’utilisateur est affiché. Le système mémorise la dernière sélection du sélecteur de formulaire.
- Si l’utilisateur n’a jamais utilisé le sélecteur de formulaire auparavant, le système utilise l’ordre de formulaire.
Si le formulaire n’est pas disponible pour l’utilisateur, le système continue de rechercher un formulaire approprié à afficher.
Un formulaire est disponible pour l’utilisateur quand :
- L’utilisateur est autorisé à accéder au formulaire.
- Le formulaire est ajouté au module d’application.
Si aucun formulaire n’est disponible pour l’utilisateur, le formulaire de base est utilisé.
Pourquoi un contrôle est désactivé/activé ou visible/masqué
Il existe de nombreuses raisons possibles pour lesquelles un contrôle peut être désactivé ou masqué lorsque le formulaire est chargé.
Procédure de résolution des problèmes
Utilisez Moniteur pour afficher l’opération FormControls
qui inclut tous les détails sur l’état de contrôle initial au moment du chargement du formulaire.
Autre possibilité de vérification : l’opération ControlStateChange.visible
ou ControlStateChange.disabled
qui explique pourquoi l’état désactivé ou visible du contrôle est modifié à tout moment sur le formulaire. Cette opération explique l’état du contrôle avant la modification, la modification d’état prévue qui peut réussir, et l’état après la modification. Toutes les tentatives de modification d’état du contrôle ne réussissent pas. Pour un contrôle désactivé par formulaire XML, vous pouvez l’activer via l’API client dans un gestionnaire d’événements OnLoad
. Cependant, si le contrôle est désactivé pour des raisons de sécurité, il est très peu probable qu’une tentative d’activation via l’API client parvienne à modifier l’état.
Un contrôle peut être désactivé à l’aide de la liste de règles suivante dans l’ordre. Si une règle est respectée, les règles suivantes sont ignorées. Si vous souhaitez modifier si un contrôle est désactivé, vous devez modifier l’entrée à la règle utilisée pour le résultat ou à une règle plus tôt dans la liste.
- Si les indicateurs
DisableWebResourceControls=true
ouDisableFormControl=<control name>
sont validés et si le contrôle est affecté par ces indicateurs, le contrôle sera désactivé. - Si la table propriétaire est en lecture seule dans Unified Interface dans les définitions de table, le contrôle est désactivé.
- Si la table n’est pas disponible en mode hors connexion, le contrôle est désactivé.
- Si l’utilisateur actuel ne dispose pas des autorisations d’écriture sur l’enregistrement, le contrôle est désactivé.
- Si la définition de colonne a la valeur
IsValidforCreate
définie sur False, le contrôle est désactivé. - Si la définition de colonne a la valeur
IsValidforUpdate
définie sur False, le contrôle est désactivé. - Si l’utilisateur actuel n’a pas le privilège
Assign to
, la colonne propriétaire est désactivée. - Si l’utilisateur ne dispose pas d’autorisations d’écriture sur la colonne définie par la sécurité au niveau du champ, le contrôle est désactivé.
- Si le script de l’API du client active ou désactive le contrôle, l’état de contrôle désactivé respectera ce paramètre.
- Si le contrôle est désactivé dans le concepteur de formulaires, le contrôle est désactivé.
- Si l’utilisateur n’a pas le privilège
Append To
pour la table du contrôle de recherche, ou le privilègeAppend
sur la table de l’enregistrement en cours, le contrôle de recherche est désactivé
Enfin, si le contrôle réussit toutes les vérifications ci-dessus, l’état d’enregistrement détermine si le contrôle est désactivé. Le contrôle est activé par défaut sur les enregistrements actifs et désactivé sur les enregistrements inactifs.
Note
La différence entre FormControls
et ControlStateChange
est que l’opération FormControls
reflète l’état du contrôle initial lorsque le formulaire est chargé tandis que l’opération ControlStateChange
reflète la modification d’état à tout moment sur le formulaire que ce soit pendant le chargement du formulaire, dans les événements OnChange ou OnSave après le chargement du formulaire.
Important
L’état désactivé et masqué d’un contrôle peut changer plusieurs fois lorsqu’un formulaire est chargé pour la première fois. Pour connaître la raison pour laquelle un contrôle est masqué ou désactivé, assurez-vous de vérifier la dernière opération enregistrée dans le moniteur. Par exemple, s’il n’y a aucune opération ControlStateChange.visible/ControlStateChange.hidden
pour le contrôle en cours d’examen, la valeur et la raison figureront dans l’opération FormControls
. Sinon, ce sera la valeur et la raison dans la dernière opération ControlStateChange.visible/ControlStateChange.hidden
. Vous pouvez trier les journaux par horodatage pour rechercher la dernière opération.
Pourquoi un contrôle a une certaine valeur lors du chargement du formulaire
Un contrôle peut avoir une valeur spécifique lors du chargement du formulaire, comme l’utilisateur l’attendait.
Procédure de résolution des problèmes
Il existe de nombreuses raisons possibles pour lesquelles le contrôle peut avoir une valeur lors du chargement d’un formulaire. L’opération ControlDefaultValue
dans Surveiller explique la source des valeurs par défaut.
Si plusieurs mises à jour sont apportées à la valeur d’un contrôle, un paramètre Update Sequence
indique la valeur finale. Par exemple, voici un contrôle avec une valeur par défaut, puis remplacé par une valeur transmise avec un script d’API client. Une pile d’appels est fournie.
Il existe des scénarios où les colonnes sont remplies en fonction d’un mappage de colonnes de relation, auquel cas l’événement le montre.
Vérifiez d’où provient la valeur et effectuez une action en vous basant sur le tableau ci-dessous :
Source | Comment le résoudre |
---|---|
API script client | Contactez le propriétaire du script. |
Valeur par défaut | Vérifiez la configuration du contrôle. |
Mappages de colonnes de relation | Vérifiez la configuration de la relation et mettez à jour le mappage de colonne. |
Valeur transmise par les données d’entrée de page transmises via l’URL | Vérifiez que l’API qui ouvre le formulaire spécifique avec le problème transmet la valeur. |
Pourquoi un onglet ou une section est visible ou masqué
Il existe de nombreuses raisons possibles pour lesquelles un onglet ou une section peut être masqué ou visible.
Procédure de résolution des problèmes
Les opérations TabStateChange
ou SectionStateChange
dans Moniteur expliquent le changement d’état visible, comme illustré dans l’image suivante. Si un script le provoque, la pile d’appels révélerait le fichier de ressource Web, le numéro de ligne et le nom de la fonction à l’origine de ce comportement.
Suivez selon la suggestion la raison de l’état ou avec le propriétaire de la ressource Web/des règles métier pour modifier ou corriger le comportement.
Navigation ou boîtes de dialogue inattendues
Il existe plusieurs raisons possibles pour expliquer l’apparition d’une boîte de dialogue ou la survenue d’une navigation inattendue. L’une des causes les plus fréquentes est l’appel des méthodes API Xrm.Navigation pour ouvrir un enregistrement ou un formulaire à l’aide d’un script personnalisé. Par exemple, si vous ouvrez un formulaire, une alerte s’affiche comme illustré dans l’image suivante.
Procédure de résolution des problèmes
L’opération XrmNavigation
dans Moniteur contient la pile d’appels qui aide à identifier le script à l’origine du comportement inattendu.
Suivez avec le propriétaire de la ressource Web pour modifier ou corriger le comportement.
Ouverture d’un autre formulaire au lieu d’un formulaire de création rapide
Lors de l’ouverture d’un formulaire de création rapide à partir d’une recherche ou d’une grille, un autre formulaire peut s’ouvrir (formulaire d’édition ou principal) au lieu d’un formulaire de création rapide. Il y a peu de raisons pour lesquelles ce problème peut arriver :
- L’indicateur de force de la boîte de dialogue du formulaire principal est en cours de définition.
- Le formulaire de création rapide n’est pas disponible.
Procédure de résolution des problèmes
Utilisez Moniteur pour afficher l’opération FormType
qui inclut toutes les raisons pour lesquelles un formulaire de création rapide ne s’ouvre pas.
Vous devez suivre avec le propriétaire de la table qui a désactivé la création rapide via les définitions de table (métadonnées).
La table n’apparaît pas dans le menu déroulant du menu de création rapide
Lors de l’ouverture du menu déroulant du menu de création rapide global, toutes les tables ne sont pas disponibles. Il y a peu de raisons pour lesquelles les tables sont filtrées dans cette liste :
- Il n’y a pas de formulaire de création rapide disponible pour la table.
- La table n’est pas activée pour le formulaire de création rapide.
- La table n’est pas activée pour la nouvelle Unified Interface.
- La table est en lecture seule sur Unified Interface.
- La visibilité du client mobile de la table ne peut pas être modifiée.
- La table ne fait pas partie du module d’application.
- L’utilisateur n’a pas de privilège de création sur la table.
- Le privilège de création n’est pas pris en charge pour la table.
Procédure de résolution des problèmes
Utilisez Moniteur pour afficher l’opération QuickCreateMenu
qui inclut toutes les tables et les raisons pour lesquelles elles sont filtrées à partir du menu déroulant du menu de création rapide.
Consultez les exemples ci-dessous pour comprendre les raisons du filtrage. Sur la base des explications, contactez la partie responsable ou apportez des modifications en conséquence.
Message inattendu des modifications non enregistrées
Lorsque vous travaillez sur des formulaires, vous affichez le message modifications non enregistrées dans le pied de page du formulaire si vous naviguez à partir du formulaire actuel ou enregistrez le formulaire sans aucune modification.
Procédure de résolution des problèmes
L’erreur modifications non enregistrées apparaît lorsque vous enregistrez le formulaire et lorsque les modifications ne sont pas enregistrées. Si vous n’avez apporté aucune modification manuellement, elles peuvent provenir d’un JavaScript, d’un plug-in ou d’une règle métier. Utilisez Moniteur pour afficher l’opération UnsavedChanges
qui aide à trouver la source des modifications. Vous pouvez filtrer par le type d’opération UnsavedChanges
.
La section all attributes modified
comprend un résumé rapide des colonnes à l’origine de l’erreur de modifications non enregistrées et de leurs valeurs. La section unsaved changes
montre ce qui est arrivé aux colonnes en détail. Pour chaque colonne, une liste de contrôles est fournie qui pourrait être à l’origine d’un changement. Le changement de valeur est également affiché (previousValue, newValue) et une pile d’appels.
La capture d’écran suivante montre la cause première du problème. Vous pouvez voir que le changement est venu du script OnLoad
.
Note
Si l’utilisateur a effectué manuellement les modifications sur le formulaire, une pile d’appels ne sera pas fournie.
Vérifiez d’où vient la modification et se le comportement est attendu ou non. Si un script provoque la modification, la ressource Web d’origine peut être suivie dans la pile d’appels. Dans la plupart des cas, il s’agit d’un script. Prenez une décision en fonction de la ressource Web elle-même.
La validation de la colonne requise par l’entreprise ne se comporte pas comme prévu
Les colonnes requises par l’entreprise bloquent par défaut l’opération d’enregistrement du formulaire si la valeur est vide. Cependant, dans de nombreux scénarios de conception, une colonne requise par l’entreprise peut ne pas bloquer l’opération d’enregistrement si la valeur est vide ou bloquer l’enregistrement lorsque vous ne le pensez pas.
Procédure de résolution des problèmes
L’opération RequiredFieldValidation
est consignée en cas de tentative d’enregistrement, que l’enregistrement soit réussi ou pas. Cette opération explique pourquoi chaque colonne requise par l’entreprise bloque ou ne bloque pas l’opération d’enregistrement.
L’image suivante est un exemple de cette opération. Le message explique comment lire les rapports détaillés de chaque colonne requise. Dans cet exemple, la colonne fax
est liée à un seul contrôle et le contrôle du même nom est en lecture seule. Par conséquent, cela ne déclenchera pas la validation de colonne requise.
L’image suivante est un autre exemple indiquant que jobtitle
est une colonne requise par l’entreprise sur le flux des processus d’entreprise mais pas sur le formulaire, et la colonne n’est pas modifiée. Ainsi, l’opération d’enregistrement n’est pas bloquée même si elle est vide.
Suivi
La plupart du temps, le comportement vient de la conception et l’opération RequiredFieldValidation
explique le comportement de cette colonne dans l’opération d’enregistrement du formulaire. Si la validation de colonne requise est ignorée sur une colonne parce que le contrôle est désactivé ou masqué, comme illustré dans le premier exemple, affichez les suggestions du vérificateur de formulaire pour approfondir l’analyse.
Ceci peut conduire à un autre scénario de résolution des problèmes tel que Pourquoi un contrôle est désactivé/activé ou visible/masqué.
Certaines colonnes ne s’affichent pas dans la boîte de dialogue de fusion
La boîte de dialogue de fusion utilise la définition du formulaire principal par défaut pour la table et rend de manière sélective la plupart (mais pas toutes) des colonnes dans la boîte de dialogue. Cette opération du vérificateur de formulaire explique pourquoi certaines colonnes ne s’affichent pas dans la boîte de dialogue de fusion, même si elles peuvent apparaitre dans le formulaire principal.
Procédure de résolution des problèmes
L’opération MergeDialog.load
suivante explique pourquoi certaines colonnes ne s’affichent pas.
Dans cet exemple, la colonne parentcustomerid
du formulaire de contact n’est pas prise en charge dans la boîte de dialogue de fusion. La colonne de la carte de visite ne s’affiche pas car la section contenante est masquée dans la définition XML du formulaire principal. Même s’il est possible d’afficher la section propriétaire dans le formulaire principal via l’API client, la boîte de dialogue de fusion respecte la configuration XML du formulaire car les gestionnaires d’événements ne sont pas pris en charge dans la boîte de dialogue de fusion.