IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

jQuery Discussion :

Update variable serveur sans recharger la page complète [AJAX]


Sujet :

jQuery

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2016
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Hautes Pyrénées (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Octobre 2016
    Messages : 6
    Points : 5
    Points
    5
    Par défaut Update variable serveur sans recharger la page complète
    Bonjour,
    Je souhaite rafraîchir mes variables c# coté serveur sans recharger la page complète.
    Je n'ai pas d'erreur mais l'appel de la procédure ne se fait pas.
    Je ne suis pas sûr non plus de la syntaxe d'appel Ajax.
    Pouvez-vous m'aider sur l'exemple suivant svp ?

    Coté client :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    @page
    @model AboutModel
    @{
         ViewData["Title"] = "TEST";
       }
     
    <script>
       function ActualiseCompteur() {
       $.ajax({
         url: '@Url.Action("SetCompteur", "About")',
         type: 'SET',
         dataType: 'html'});
         }
       setInterval(function () { ActualiseCompteur(); }, 1000);
    </script>
     
    <h2>@ViewData["Title"]</h2>
     
     
    <p>@ViewData["Compteur"]</p>

    Coté serveur :
    Code c# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    public int compteur;
    public void SetCompteur()
    {
       compteur++;
       ViewData["Compteur"] = "Compteur = " + compteur;
    }
    Merci de votre aide.

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    16 959
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 122
    Points
    44 122
    Par défaut
    Bonjour,
    au moins deux choses :
    • Ta balise <script> n'est pas une balise de fermeture à ligne 15
    • Jette un oeil à la documentation : jQuery.ajax()

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2016
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Hautes Pyrénées (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Octobre 2016
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    Merci NoSmoking,
    En fait, c'est un mauvais copié/collé pour la balise.
    Sinon, pour le reste, est-ce que j'utilise la bonne méthode pour appeler ma procédure SetCompteur ?
    Merci.

  4. #4
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 637
    Points : 66 658
    Points
    66 658
    Billets dans le blog
    1
    Par défaut
    je ne vois pas d'action lors du success d'ajax ?
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  5. #5
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    16 959
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 122
    Points
    44 122
    Par défaut
    Que dit la documentation, que tu as sûrement lue ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $.ajax({
      method: "POST", // 
      url: "url-de-la-page",
      data: {
        "action": "actionServeur",
        "parametre": "Le paramètre a passer"
      }
    }).done(function(retour) {
      console.log("retour :", retour);
    });
    mais côté serveur il me semble que tu récupères les données d'une autre manière en C#.

    Renseignement pris cela devrait ressembler à
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $.ajax({
      method: "POST", // 
      url: "url-de-la-page/actionServeur",
      data: {
        "parametre": "Le paramètre a passer"
      }
    }).done(function(retour) {
      console.log("retour :", retour);
    });
    ou quelque chose d'approchant.

  6. #6
    Futur Membre du Club
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2016
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Hautes Pyrénées (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Octobre 2016
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    J'ai trouvé mon problème.

    Je n'avais pas vu le message dans l'interface de sortie en debug :
    Microsoft.AspNetCore.Mvc.ViewFeatures.Internal.AutoValidateAntiforgeryTokenAuthorizationFilter:Information: Antiforgery token validation failed. The required antiforgery cookie ".AspNetCore.Antiforgery.yh1KSrS6f9o" is not present.
    J'ai résolu en ajoutant dans le fichier Startup.cs:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    services.AddMvc().AddRazorPagesOptions(options =>
                {
                    options.Conventions.ConfigureFilter(new IgnoreAntiforgeryTokenAttribute());
                });
    Ce n'est pas une solution très propre mais cela m'a permis de comprendre que j'instanciais une nouvelle page et créais donc un doublon.

    Je vais pouvoir implémenter en appelant une autre page.

    Merci pour tes recherches.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Actualisation de valeur de variable sans rechargement de page
    Par KOEOS dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 27/08/2019, 09h29
  2. Réponses: 0
    Dernier message: 17/02/2019, 16h49
  3. Afficher une div en fonction d'une variable, sans rechargement de page
    Par skurseb dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 13/02/2012, 09h23
  4. [AJAX] Comment envoyer au serveur une seul info sans recharger la page
    Par Ekimasu dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 15/11/2007, 12h10
  5. Réponses: 4
    Dernier message: 06/11/2007, 11h44

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo