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

JavaScript Discussion :

Nombre d'arguments variable


Sujet :

JavaScript

  1. #1
    Futur Membre du Club
    Inscrit en
    Janvier 2013
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Janvier 2013
    Messages : 8
    Points : 5
    Points
    5
    Par défaut Nombre d'arguments variable
    Bonjour à tous,
    J'ai un tp à faire dans le cadre de mes études en informatique.
    Ci dessous, le code JavaScript.
    J'ai implementer la function sub() sans trop de soucis, en revanche je doit modifier la fonction adder afin qu'elle acceptee un nombre variable d'argument tel que :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    adder()(0); // 0
    adder()(1); // 0
    adder(mult(2))(1); // 2
    adder(mult(2), mult(2))(1); // 4
    adder(mult(2), mult(2), mult(2))(1); // 6
    adder(mult(2), sub(2), mult(2))(1); // 5
    Mon professeur m'indique d'utiliser :
    -->
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    var args = Array.prototype.slice.call(arguments);
    [1,2,3].forEach(function(val){console.log(val);});
    Mais je ne comprend pas trop.

    Code : 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
    function adder(l,r){
      return function(v){
        return l(v) + r(v);
      }
    }
     
    function mult(v){
      return function(e){
        return v*e;
      }
    }
    function sub(x,y)
    {
            return x-y;
    }
    console.log(adder(mult(2), mult(4))(2));
    console.log(sub(0,0));
    console.log(sub(2,1));
    console.log(sub(2,2));
    console.log(sub(2,4));
    Pouvez vous m'aider s'il vous plait ?
    Merci d'avance.

  2. #2
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    Ton prof t'a donné tout ce dont tu as besoin
    La première ligne récupère les arguments passés dans la fonction en cours sous forme d'Array.
    La seconde montre comment exécuter facilement une fonction sur chaque élément d'un Array. Bien qu'une boucle for fait tout aussi bien dans ton cas.
    One Web to rule them all

  3. #3
    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 640
    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 640
    Points : 66 670
    Points
    66 670
    Billets dans le blog
    1
    Par défaut
    Je ne suis pas fan du prototype ...
    personnellement quand j'ai besoin de passer un nombre d'arguments variable je passe un json ...
    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 !

  4. #4
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    fan du prototype ? tu veux dire caster les arguments en Array ? Je ne vois quel est le problème avec ça. Ca me parait tout à fait approprié pour le problème de la calculatrice en notation polonaise.
    One Web to rule them all

  5. #5
    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 640
    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 640
    Points : 66 670
    Points
    66 670
    Billets dans le blog
    1
    Par défaut
    je n'aime pas surcharger, j'ai eu trop de surprises pars le passé

    j'ai juste pris l'habitude des passer un json en paramètre ce qui me parait beaucoup plus souple et moins contraignant et ne génère aucune surprise par la suite
    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 !

  6. #6
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    Mais ici on ne surcharge rien du tout. On appelle simplement la fonction slice issue du prototype d'Array pour obtenir les arguments de la fonction sous la forme d'une Array. C'est quelque-chose de tout à fait courant
    One Web to rule them all

  7. #7
    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 640
    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 640
    Points : 66 670
    Points
    66 670
    Billets dans le blog
    1
    Par défaut

    en effet pas de surcharge... c'est juste prototype qui me colle des boutons ...
    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 !

  8. #8
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var args = [].slice.call(arguments);
    Ca va mieux
    One Web to rule them all

  9. #9
    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 640
    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 640
    Points : 66 670
    Points
    66 670
    Billets dans le blog
    1
    Par défaut
    oui ^^ merci
    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 !

  10. #10
    Futur Membre du Club
    Inscrit en
    Janvier 2013
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Janvier 2013
    Messages : 8
    Points : 5
    Points
    5
    Par défaut
    Je ne comprend vraiment pas comment faire
    Je met le tableau ici, en placant arguments en parametre de la fonction, est-ce bon ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    function adder(arguments){
    var args = Array.prototype.slice.call(arguments);
     
    	return function(v){
        return l(v) + r(v);
    }

  11. #11
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    arguments contient la liste des arguments passé en fonction, il est inutile de l'indiquer dans la déclaration. Peut-être que ceci vous mettra sur la voie :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    function adder(){
    var args = Array.prototype.slice.call(arguments);
     
    for(var a=0; a<args.length; a++){
          alert(args[a]);
    }
     
    }
     
    adder(1,2,3);
    One Web to rule them all

  12. #12
    Expert éminent
    Avatar de Watilin
    Homme Profil pro
    En recherche d'emploi
    Inscrit en
    Juin 2010
    Messages
    3 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : En recherche d'emploi

    Informations forums :
    Inscription : Juin 2010
    Messages : 3 094
    Points : 6 755
    Points
    6 755
    Par défaut
    Moi aussi le prototype m'ennuie, mais pour une autre raison. Ça me dérange d'avoir recours à la méthode slice alors qu'au final on ne slice pas le tableau.

    Les navigateurs pas trop vieux proposent des méthodes génériques pour Array, notamment une version générique de forEach. Ça fait du code plus court :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    function adder() {Array.forEach(arguments, function(arg) {});
      …
    }
    La méthode reduce est à mon goût la plus élégante pour résoudre ce genre de problème, mais elle est peut-être un peu difficile à comprendre au début. Il y a aussi map qui peut être intéressante.
    La FAQ JavaScript – Les cours JavaScript
    Touche F12 = la console → l’outil indispensable pour développer en JavaScript !

  13. #13
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    Oui c'est sûr que Array.reduce est plus approprié ici, il suffit d'écrire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    function adder() {
      return [].reduce.call(arguments, function(res, arg){ return res+arg; });    
    }
    Je pense que le prof a parlé du slice car c'est un moyen générique de récupérer les arguments sous forme de vraie Array ; le genre de trucs qu'on peut réutiliser partout sans risques.
    One Web to rule them all

  14. #14
    Expert éminent
    Avatar de Watilin
    Homme Profil pro
    En recherche d'emploi
    Inscrit en
    Juin 2010
    Messages
    3 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : En recherche d'emploi

    Informations forums :
    Inscription : Juin 2010
    Messages : 3 094
    Points : 6 755
    Points
    6 755
    Par défaut
    reduce aussi a une version générique :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    function adder() {
      return Array.reduce(arguments, function(res, arg){ return res + arg; });    
    }
    Dans l'enseignement on s'en fout que ça marche sous IE4, l'important c'est que l'élève comprenne. Et quitte à enseigner une technologie qui évolue rapidement telle que JavaScript, autant enseigner les pratiques modernes.

    Tiens tant qu'à faire, on a les fonctions lambda :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    function adder() Array.reduce(arguments, function(res, arg) res + arg);
    Ou même carrément les fonctions arrow du futur standard ES6 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    function adder() => Array.reduce(arguments, (res, arg) => res + arg);
    La FAQ JavaScript – Les cours JavaScript
    Touche F12 = la console → l’outil indispensable pour développer en JavaScript !

  15. #15
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    Citation Envoyé par Watilin Voir le message
    Dans l'enseignement on s'en fout que ça marche sous IE4, l'important c'est que l'élève comprenne. Et quitte à enseigner une technologie qui évolue rapidement telle que JavaScript, autant enseigner les pratiques modernes.
    Oui mais non. Assurer le support des anciens navigateurs, ça fait partie de l'enseignement. Je n'ai pas trop envie de voir débarquer un stagiaire dans ma boîte qui commence à coder en ES6 sans savoir ce qu'est un polyfill. A ce niveau là de l'enseignement, on prépare l'élève au monde de l'entreprise. Et dans le monde de l'entreprise, il n'y a pas beaucoup de monde qui peut se permettre le luxe de lâcher le support d'IE8.

    Par ailleurs, les versions génériques des méthodes d'Array ne font pas partie des normes EcmaScript5 (voir https://developer.mozilla.org/en-US/...eneric_methods).
    One Web to rule them all

  16. #16
    Membre émérite
    Avatar de Kaamo
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    1 165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 165
    Points : 2 778
    Points
    2 778
    Par défaut
    Et pour l'onanisme intellectuel, cette technique a un nom : le Currying (Curryfication en français)

Discussions similaires

  1. Un script shell avec nombre d'argument variable
    Par lastrecrue dans le forum Linux
    Réponses: 1
    Dernier message: 28/05/2006, 11h35
  2. méthodes avec nombres d'arguments variable
    Par spynux dans le forum Langage
    Réponses: 2
    Dernier message: 26/05/2006, 13h51
  3. Réponses: 4
    Dernier message: 31/10/2005, 17h48
  4. Macros et nombre d'arguments variable
    Par kaisse dans le forum C
    Réponses: 7
    Dernier message: 28/07/2005, 10h10
  5. Nombre d'arguments variable
    Par gege2061 dans le forum C
    Réponses: 7
    Dernier message: 05/08/2004, 15h43

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