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
Libérer: 2024-12-24 10:52:15
original
522 Les gens l'ont consulté

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}}
    Copier après la connexion
  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
      }
    }
    Copier après la connexion
  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();
    }
    Copier après la connexion

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!

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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal