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

ASP.NET Discussion :

Notation de plusieur éléments avec les étoiles [Débutant]


Sujet :

ASP.NET

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2017
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2017
    Messages : 3
    Points : 6
    Points
    6
    Par défaut Notation de plusieur éléments avec les étoiles
    Bonjour

    j'ai une liste qui s'affiche d'une manière dynamique et j'ai intégré la notation sauf que si je met le curseur sur les étoiles de la deuxième ou Nème élément de la liste c'est toujours les étoiles du premier qui change de couleur. comment je peux les différenciers

    <div class="table-responsive">
    <table class="table table-inbox table-lg">
    <tbody data-link="row" class="rowlink">
    <tr class="unread">
    <td class="table-inbox-name">
    <a href="#">
    <div class="letter-icon-title text-default">
    Numéro commande
    </div>
    </a>
    </td>
    <td class="table-inbox-message">
    Date de commande
    </td>
    <td class="table-inbox-message">
    Note
    </td>

    </tr>
    @if (Model.Commandes != null)
    {

    foreach (var item in Model.Commandes)
    {

    <tr class="unread">
    <td class="table-inbox-name">
    <a href="#">
    <div class="letter-icon-title text-default">
    @Html.DisplayFor(modelItem => item.Id)
    </div>
    </a>
    </td>
    <td class="table-inbox-message">
    @Html.DisplayFor(modelItem => item.DateCommande)
    </td>

    <td class="table-inbox-message">
    @if (item.Rating != 0)
    {
    <div class="form-group">

    <div onmouseout="CRateSelected()">
    @for (var i = 1; i <= item.Rating; i++)
    {
    <span class="starGlow" id="Rate_@i" onclick="CRate(@i,item.Id)" onmouseover="CRateOver(@i)" onmouseout="CRateOut(@i)"></span>
    }
    @for (var i = (item.Rating + 1); i <= 5; i++)
    {
    <span class="starFade" id="Rate_@i" onclick="CRate(@i)" onmouseover="CRateOver(@i)" onmouseout="CRateOut(@i)"></span>
    }
    </div>
    </div>
    }

    else
    {
    <div class="form-group">

    <div class="col-md-7 ">
    <div onmouseout="CRateSelected()">
    <span class="starFade" id="Rate_1" onclick="CRate(1)" onmouseover="CRateOver(1)" onmouseout="CRateOut(1)"></span>
    <span class="starFade" id="Rate_2" onclick="CRate(2)" onmouseover="CRateOver(2)" onmouseout="CRateOut(2)"></span>
    <span class="starFade" id="Rate_3" onclick="CRate(3)" onmouseover="CRateOver(3)" onmouseout="CRateOut(3)"></span>
    <span class="starFade" id="Rate_4" onclick="CRate(4)" onmouseover="CRateOver(4)" onmouseout="CRateOut(4)"></span>
    <span class="starFade" id="Rate_5" onclick="CRate(5)" onmouseover="CRateOver(5)" onmouseout="CRateOut(5)"></span>
    </div>
    </div>
    </div>
    }

    </td>
    </tr>
    }
    }

    et voilà le script

    function CRate(r) {
    $("#Rating").val(r);
    for (var i = 1; i <= r; i++) {
    $("#Rate_" + i).attr('class', 'starGlow');
    }
    // unselect remaining
    //for (var i = r + 1; i <= 5; i++) {
    // $("#Rate " + i).attr('class', 'starFade');
    //}
    }

    function CRateOver(r) {
    for (var i = 1; i <= r; i++) {
    $("#Rate_" + i).attr('class', 'starGlow');
    }
    for (var s = i; s <= 5; s++) {
    $("#Rate_" + s).attr('class', 'starFade');
    }
    }

    function CRateOut(r) {
    for (var i = 1; i <= r; i++) {
    $("#Rate_" + i).attr('class', 'starFade');
    }
    }

    function CRateSelected() {
    var setRating = $("#Rating").val();
    for (var i = 1; i <= setRating; i++) {
    $("#Rate_" + i).attr('class', 'starGlow');
    }
    for (var s = i; s <= 5; s++) {
    $("#Rate_" + s).attr('class', 'starFade');
    }
    }

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    777
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2003
    Messages : 777
    Points : 1 077
    Points
    1 077
    Par défaut
    Salut,

    c'est plutot un problème JS que ASP.NET.
    Tu devrais préciser dans tes étoiles l'id de ta commande en plus de l'index afin de le rendre vraiment unique. (Sinon tu récupère le premier élément qui correspond et qui sera forcément toujours ta première commande...)
    Ensuite dans tes événements tu pourrais passer directement l'objet "span" avec le mot clé "this".

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <span class="starGlow" id="Rate_@i_@item.Id" onclick="CRate(this)" onmouseover="CRateOver(this)" onmouseout="CRateOut(this)"></span>
    Maintenant tu es certain d'être sur la bonne balise, tu n'as plus qu'a faire ton traitement...

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2017
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2017
    Messages : 3
    Points : 6
    Points
    6
    Par défaut
    Merci infiniment

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    777
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2003
    Messages : 777
    Points : 1 077
    Points
    1 077
    Par défaut
    Citation Envoyé par AmineDm Voir le message
    Merci infiniment
    Tu peux marqué la discussion comme résolu

    A+

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

Discussions similaires

  1. Réponses: 10
    Dernier message: 30/04/2015, 11h00
  2. Réponses: 2
    Dernier message: 21/10/2012, 23h35
  3. Requete sur plusieurs table avec les memes champs
    Par broule dans le forum Langage SQL
    Réponses: 4
    Dernier message: 05/02/2010, 19h57
  4. Script d'évaluation avec les étoiles
    Par L'aigle de Carthage dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 15/03/2008, 13h38
  5. Plusieurs compositions avec les DynaValidatorForm
    Par TravelMate dans le forum Struts 1
    Réponses: 7
    Dernier message: 21/11/2006, 14h29

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