Interagissez avec les ressources HTTP et HTTPS de manière asynchrone
Catégorie : Performance
Potentiel d’impact : Élevé
Symptômes
Les requêtes synchrones bloquent l’exécution d’autres scripts, qui peuvent entraîner comme suit :
- Des applications basées sur des modèles et des applications canevas qui ne répondent pas
- Des interactions lentes avec le client
Recommandation
Interagissez de manière asynchorne avec les ressources HTTP et HTTPS chaque fois que possible Les utilisateurs doivent remarquer des améliorations dans le délai de chargement réel des pages ou la vitesse de chargement de page perçue. La réactivité de la page doit également augmenter.
Les options suivantes sont disponibles dans les navigateurs modernes pour interagir avec des services asynchrones.
Note
L’ajout d’interactions asynchrones nécessite un style différent de conception des interactions synchrones. Les rappels peuvent s’exécuté dans un ordre non déterministe, ce qui signifie vous devez réfléchir davantage à garantir que le flux et l’intégrité de la page sont corrects à tout moment. Par exemple, vous devrez souvent mettre en place des mesures pour garantir que les contrôles ne sont pas activés jusqu’à ce que tous les appels de services dépendants soient retournés. Effectuer quelques étapes supplémentaires peut garantir une expérience utilisateur plus agréable.
En règle générale, les règles de ruban ont été entrées avec des demandes synchrones comme true/false devait être renvoyé. Unified Interface prend en charge une promise de retour plutôt qu’une valeur booléenne, ce qui permet aux règles du ruban d’émettre des requêtes réseau asynchrones. Pour plus d’informations, voir Définir les règles d’activation du ruban.
XMLHttpRequest
avec le paramètre asynchrone omis ou défini sur True// Missing the async parameter, which is the third parameter. It defaults to true, which is the value you want. var requestXhr = new XMLHttpRequest(); requestXhr.open('GET', '/test/test.txt'); // Explicitly setting the async parameter. requestXhr.open('GET', '/test/test.txt', true);
Utilisation de l’API Fetch
Important
Avant de procéder avec cette option, vérifiez que la prise en charge est disponible pour les navigateurs utilisés pour interagir avec vos personnalisations. Consultez la section Compatibilité du navigateur de la documentation Fetch.
Schémas problématiques
Il existe diverses manières d’interagir avec le serveur ou de demander des ressources. Les méthodes courantes qui permettent des communications synchrones comprennent :
Avertissement
Ces scénarios doivent être évités.
Utilisation de l’objet
XMLHttpRequest
transmis enfalse
pour la valeur du paramètreasync
pour l’appel de fonctionopen
var requestXhr = new XMLHttpRequest(); // Explicitly setting the async parameter to false or supplying a variable with a value of false will force this as a synchronous call. requestXhr.open('GET', '/test/test.txt', false);
Utilisation de la fonction
jQuery
ajax
, qui transmetfalse
pour la valeur du paramètreasync
// Explicitly setting the async parameter to false or supplying a variable with a value of false will force this as a synchronous call. var requestAjax = $.ajax({ async: false, url: '/test/test.txt' });
Spécifiques aux interactions avec les services Dynamics 365, il existe des bibliothèques JavaScript qui fournissent des opérations explicites aux interactions courantes avec le produit. Les bibliothèques courantes incluent (sans y être limitées) :
SDK.REST.js
,SDK.Soap.js
etXrmServiceToolkit.js
.- Pour ces éléments, certaines fonctions prenant en charge uniquement les opérations synchrones ; d’autres nécessitent le transfert d’une fonction de rappel comme paramètre pour définir l’async sur True. Le comportement par défaut pour la plupart consiste à définir le paramètre sous-jacent d’async sur false pour l’appel ouvert de l’objet
XMLHttpRequest
.
- Pour ces éléments, certaines fonctions prenant en charge uniquement les opérations synchrones ; d’autres nécessitent le transfert d’une fonction de rappel comme paramètre pour définir l’async sur True. Le comportement par défaut pour la plupart consiste à définir le paramètre sous-jacent d’async sur false pour l’appel ouvert de l’objet
Informations supplémentaires
Niveau de performance
Un navigateur interprète le script est un thread unique. Si ce thread est utilisé pour exécuter un processus de manière synchrone, le navigateur cessera de répondre aux interactions de l’utilisateur (« se fige ») en attendant que le processus se termine. Les appels synchrones peuvent également supprimer la possibilité d’effectuer plusieurs interaction simultanément, forçant tous les appels à être en série de nature. Dans de nombreux cas, cela provoque de la frustration chez vos utilisateurs. Optimisez la réactivité de l’utilisateur en intégrant des appels de service asynchrones.
Prise en charge par les navigateurs Web
La spécification pour XMLHttpRequest
indique que l’utilisation synchrone est supprimée de la norme car elle est maintenant obsolète. Actuellement, les navigateurs présentent uniquement des avertissements, mais une exception InvalidAccessError
peut être levée à l’avenir lorsqu’une valeur False est passée au paramètre d’async. Les navigateurs modernes ont déclaré les demandes synchrones exécutées vis-à-vis du thread principal comme obsolètes.
Note
Des API modernes sont introduites qui ne fourniront plus d’option pour des opérations synchrones. Reportez-vous à la documentation de l’API Fetch pour plus de détails.
window.setTimeout
Bien que l’inclusion de blocs de scripts sous la forme d’un paramètre dans la fonction window.setTimeout
interrompt le flux synchrone normal de l’exécution de page, il n’accomplit pas le traitement parallèle.
window.setTimeout(
function () {
var oReq = new XMLHttpRequest();
oReq.open('GET', '/test/action', false);
}, 0);
L’approche de cet exemple continue de traiter le thread d’interface utilisateur du navigateur principal, ce qui verrouille le navigateur.
Voir aussi
Définir les règles d’activation du rubanXMLHttpRequest
Spécification XMLHttpRequest (avec notification d’obsolescence synchrone)
Spécification de l’API Fetch
API Fetch