Les systèmes de notation entre zéro et cinq étoiles sont monnaie courante sur internet, tout particulièrement sur les places de marché et les boutiques en ligne pour noter les produits. Les moteurs de recherchent relaient parfois même cette information dans les SERP si elle est issue d’un tiers de confiance.
Je vous propose ci-après une méthode simple et basée sur Javascript et jQuery pour afficher un curseur étoilé à l’écran, et permettre à l’utilisateur de choisir sa note. Nous n’irons pas au-delà et ne traiteront pas l’action AJAX résultant du clic d’une étoile, qui entraînera pas exemple la mémorisation en base de données etc. Attention, cet article s’adresse en priorité aux développeurs qui pourront peut-être trouver des idées pour leurs projets, et seront en mesure de comprendre et d’adapter le code à leurs besoins.
J’ai choisi d’utiliser Font Awesome pour avoir le choix parmi différents visuels, mais j’aurai pu tout autant utiliser le caractère Unicode U+2605 pour l’étoile ★.
La librairie jQuery est ici utilisée car c’est souvent une dépendance dans mes projets web. Ici elle n’est utilisée que pour le sélecteur $(this) ainsi que les sélecteurs CSS. Tout autre librairie JS comme Sizzle fera l’affaire également (code à adapter).
Démonstration :
Dans la page web, voici comment initialiser la classe Javascript en ajoutant un curseur étoilé après chaque balise <li> .
1 2 3 4 5 6 |
$('li').each(function() { $(this).append(objRate.initRate(objRate.maxRate)); }); $('.fa-star-o, .fa-star').on('mouseenter mouseleave', objRate.hoverHandler); $('.fa-star-o, .fa-star').on('click', objRate.clickHandler); |
Ma classe Javascript rate.class.js, ou plutôt mon ensemble de prototypes, se présente comme ceci.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
function classRate() { this.counter = 0; this.maxRate = 4; } classRate.prototype.initRate = function(intMax) { this.counter++; var str = '<span id="grade-'+this.counter+' class="rate" data-maxgrade="'+intMax+'">'; for (var i=1; i<=intMax; i++) { str += '<i class="fa fa-star-o" data-clicked="false" data-id="grade-'+this.counter+'" data-grade="'+i+'"></i>'; } str += '</span>'; return str; } classRate.prototype.hoverHandler = function(eventObject) { var data_id = eventObject.target.dataset.id; var data_grade = eventObject.target.dataset.grade; var className = eventObject.target.className; if (className == 'fa fa-star-o') { for (var i=1; i<=data_grade; i++) { $('[data-id="'+data_id+'"][data-grade="'+i+'"]').removeClass('fa-star-o'); $('[data-id="'+data_id+'"][data-grade="'+i+'"]').addClass('fa-star'); } } else if (className == 'fa fa-star') { for (var i=1; i<=data_grade; i++) { $('[data-id="'+data_id+'"][data-grade="'+i+'"]').removeClass('fa-star'); $('[data-id="'+data_id+'"][data-grade="'+i+'"]').addClass('fa-star-o'); } } return false; } classRate.prototype.clickHandler = function(eventObject) { var data_id = eventObject.target.dataset.id; var data_grade = eventObject.target.dataset.grade; console.log(data_grade); $('[data-id="'+data_id+'"]').off('mouseenter mouseleave'); // De 1 à coché : est coché for (var i=1; i<=data_grade; i++) { console.log('a'+i); $('[data-id="'+data_id+'"][data-grade="'+i+'"]').removeClass('fa-star-o'); $('[data-id="'+data_id+'"][data-grade="'+i+'"]').addClass('fa-star'); $('[data-id="'+data_id+'"][data-grade="'+i+'"]').attr('data-clicked', "true"); } // De coché+1 à maxRate : n'est est coché next = parseInt(data_grade)+1; for (var i=next; i<=objRate.maxRate; i++) { console.log('b'+i); $('[data-id="'+data_id+'"][data-grade="'+i+'"]').removeClass('fa-star'); $('[data-id="'+data_id+'"][data-grade="'+i+'"]').addClass('fa-star-o'); $('[data-id="'+data_id+'"][data-grade="'+i+'"]').attr('data-clicked', "false"); } return false; } objRate = new classRate(); |
On remarque la présence de variables propres à la classe. L’entier counter sert à comptabiliser le nombre de curseurs étoilés sur la page, et l’entier maxRate détermine la note maximale possible en nombre d’étoiles.
Concernant les fonctions :
- hoverHandler : la fonction handler dans le trigger d’évènement $('.fa-star-o, .fa-star').on('mouseenter mouseleave', objRate.hoverHandler);
- clickHandler : la fonction handler dans le trigger d’évènement $('.fa-star-o, .fa-star').on('click', objRate.clickHandler);
Les deux micro-astuces de ce système sont :
- Pour conserver le statut du curseur après clic, on désactive le trigger « mouseenter mouseleave » plutôt que de rajouter un trigger de modification et figeage de l’état.
- Lors d’un clic, on traite les étoiles inférieures ou égales à celle cliquée, puis ensuite on traite les autres pour s’assurer que leur visuel est cohérent.
La page web qui va avec cet exemple est la suivante :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
<!DOCTYPE html> <html> <head> <title>Curseur étoilé</title> <meta charset="utf-8" /> <link rel="stylesheet" href="css/font-awesome-4.7.0/css/font-awesome.min.css" /> <style> span[id^="grade-"]:hover { opacity: 0.5; } </style> <script type="text/javascript" src="js/jquery-2.1.3.min.js"></script> <script type="text/javascript" src="js/rate.class.js"></script> <script type="text/javascript"> $(function() { $('li').each(function() { $(this).append(objRate.initRate(objRate.maxRate)); }); $('.fa-star-o, .fa-star').on('mouseenter mouseleave', objRate.hoverHandler); $('.fa-star-o, .fa-star').on('click', objRate.clickHandler); }); </script> </head> <body> <ol> <li>Curseur étoilé 1 </li> <li>Curseur étoilé 2 </li> </ol> </body> </html> |
Envie d’incorporer ce système de notation dans un menu déroulant et contextuel ? Suivez la méthode illustrée dans mon article.