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

亚连
亚连original
2018-05-24 09:49:011723parcourir

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);
      }

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)

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);
  }
 }
}

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!

Déclaration:
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