Maison > interface Web > js tutoriel > Le principe d'AJAX : comment réaliser un rafraîchissement asynchrone et partiel

Le principe d'AJAX : comment réaliser un rafraîchissement asynchrone et partiel

亚连
Libérer: 2018-05-24 09:49:01
original
1706 Les gens l'ont consulté

Comment réaliser un rafraîchissement asynchrone et partiel ? L'éditeur ci-dessous vous proposera un article sur les principes d'AJAX : comment réaliser une actualisation asynchrone et partielle. Maintenant, je le partage avec vous et le donne comme référence.

Présentation : si onReadyStateChange se voit attribuer une valeur par la fonction de rappel, elle peut être appelée de manière asynchrone et la fonction de rappel exploite directement le DOM, afin qu'elle puisse obtenir un rafraîchissement partiel. Alors, comment onReadyStateChange de XMLHttpRequest sait-il que le service est prêt ? Comment l’état change-t-il (mode observateur) ? Ceci est réalisé grâce à la demande de statut du client (interrogation régulière) du service.

Explication détaillée :

1 XMLHttpRequest est responsable de la communication avec le serveur, et il existe de nombreux attributs importants : readyStatus=4, status=200, etc. Lorsque l'état global de XMLHttpRequest est garanti terminé (readyStatus=4), les données ont été envoyées. Ensuite, interrogez l'état de la demande en fonction des paramètres du serveur (de la même manière que le client interroge l'état de retour du serveur, toujours une connexion http courte, pas une longue connexion côté serveur. Si tout est prêt (statut = 200), alors exécutez requis). opération.

L'opération consiste généralement à faire fonctionner directement le DOM, afin qu'AJAX puisse obtenir l'expérience utilisateur dite « sans rafraîchissement ».

document.getElementById("user1").innerHTML = "数据正在加载...";
      if (xmlhttp.status == 200) {
        document.write(xmlhttp.responseText);
      }
Copier après la connexion

2. Alors comment le faire de manière asynchrone sur le client AJAX ? En fait, c'est le rôle de la fonction de rappel Javascript

Fournit une fonction de rappel JavaScript, qui est exécutée une fois la réponse du serveur disponible

Fonction métier :

function castVote(rank) {
 var url = "/ajax-demo/static-article-ranking.html";
 var callback = processAjaxResponse;
 executeXhr(callback, url);
}
需要异步通讯的函数: 


function executeXhr(callback, url) {
 // branch for native XMLHttpRequest object
 if (window.XMLHttpRequest) {
  req = new XMLHttpRequest();
  req.onreadystatechange = callback;
  req.open("GET", url, true);
  req.send()(null);
 } // branch for IE/Windows ActiveX version
 else if (window.ActiveXObject) {
  req = new ActiveXObject("Microsoft.XMLHTTP");
  if (req) {
   req.onreadystatechange = callback;
   req.open("GET", url, true);
   req.send()();
  }
 }
}
req.onreadystatechange = callback
req.open("GET", url, true)
Copier après la connexion

La première ligne définit une fonction de rappel JavaScript qui est automatiquement exécutée une fois la réponse prête, et l'indicateur "true" spécifié dans la méthode req.open() indique que la requête doit être exécutée de manière asynchrone.

Une fois que le serveur a traité le XmlHttpRequest et l'a renvoyé au navigateur, la méthode de rappel définie à l'aide de l'affectation req.onreadystatechange sera automatiquement appelée.

Fonction de rappel :

function processAjaxResponse() {
 if (req.readyState == 4) {
  // only if "OK"
  if (req.status == 200) {
   document.getElementById("user1").innerHTML = req.responseText;
  } else {
   alert("There was a problem retrieving the XML data:
" + req.statusText);
  }
 }
}
Copier après la connexion

Ce qui précède est ce que j'ai compilé pour vous. J'espère que cela vous sera utile à l'avenir. .

Articles connexes :

Analyse approfondie de la mise en œuvre par Nginx des problèmes de requêtes inter-domaines AJAX

Comment utiliser le contrôle Rating d'AjaxToolKit

Téléchargement de fichiers avec barre de progression basée sur la technologie Ajax

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal