Maison >développement back-end >Golang >Comment mettre à jour dynamiquement les partiels de modèles dans Go ?

Comment mettre à jour dynamiquement les partiels de modèles dans Go ?

Linda Hamilton
Linda Hamiltonoriginal
2024-12-24 10:52:15524parcourir

How to Dynamically Update Template Partials in Go?

Mettre à jour dynamiquement les partiels d'un modèle dans Go

Dans Go, la possibilité d'actualiser une partie d'un modèle lorsqu'une variable est modifiée n'est pas intrinsèque soutenu. Pour obtenir cette fonctionnalité, une solution personnalisée doit être implémentée.

Étapes de mise en œuvre :

  1. Modèles de refactorisation : Extrayez la section rendant le Adresses dans un bloc de modèle séparé en utilisant {{define "Addresses"}} ou {{block "Adresses"}}.
  2. Modifier/Créer des gestionnaires : Créez un gestionnaire qui exécute exclusivement le modèle d'adresses et envoie la sortie à la réponse HTTP. Ce gestionnaire peut être utilisé indépendamment ou dans le gestionnaire du modèle de page complète.
  3. Logique côté client : Côté client, effectuez un appel AJAX au gestionnaire d'adresses lorsque vous en avez besoin. mettre à jour les adresses affichées. Remplacez le contenu de l'élément wrapper Addresses par la réponse de l'appel AJAX.

Étapes détaillées :

  1. Modèle Refactoring :

    {{define "Addresses"}}
      <ul>
      {{range $key, $value := .Addresses}}
     <li>{{ $key }}: {{ $value }}</li>
      {{end}}
      </ul>
    {{end}}
  2. Modification du gestionnaire :

    import "net/http"
    
    func AddressesHandler(w http.ResponseWriter, r *http.Request) {
      data := map[string]string{"Addresses": []string{"Address1", "Address2"}}
      t, err := template.New("AddressesTemplate").Parse("{{define "Addresses"}}{{.Addresses}}{{end}}")
      if err != nil {
     http.Error(w, http.StatusInternalServerError.String(), http.StatusInternalServerError)
     return
      }
      err = t.ExecuteTemplate(w, "Addresses", data)
      if err != nil {
     http.Error(w, http.StatusInternalServerError.String(), http.StatusInternalServerError)
     return
      }
    }
  3. Côté client Implémentation :

    var addressesElement = document.getElementById("addresses");
    
    function refreshAddresses() {
      var xhr = new XMLHttpRequest();
      xhr.open("GET", "/addresses", true);
      xhr.onreadystatechange = function() {
     if (xhr.readyState === 4 && xhr.status === 200) {
       addressesElement.outerHTML = xhr.responseText;
     }
      };
      xhr.send();
    }

Cadre alternatif :

Gowut est un framework Web Go qui fournit des fonctionnalités similaires pour les mises à jour partielles dynamiques dans pages Web.

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