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 :

Conflits avec "$(function () {"


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2013
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2013
    Messages : 13
    Par défaut Conflits avec "$(function () {"
    Bonsoir à tous !

    En développant un petit formulaire avec différents modules, je me rend compte, qu'en ajoutant des fonctions, d'autres marchent plus.. Etant étudiant, je ne maîtrise pas tout les langages a fond..


    Dans mon code, j'ai une partie
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <script type="text/javascript"></script>
    , qui contient l'intégralité de mes fonctions.

    Je ne comprend pas certaines fonctions formatées comme ceci par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $(function () {
            $('#datetimepicker3').datetimepicker({
                pickDate: false,
                pickSeconds: false,         // disables seconds in the time picker
                pick12HourFormat: false,   // enables the 12-hour format time picker
            });
        });
    Quand est-ce que ces fonctions s'éxécutent ? Comment sont elles appelées ?
    C'est ces fonctions qui me posent problème, puis-je les définir comme des fonctions Javascript normales ? :
    Pouvez vous m'éclaircir ?..

  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
    Par défaut
    Ce sont des fonctions Javascript normales.

    Ce bout de code est spécifique à jQuery. Quand tu passes une fonction en argument à la fonction $ (qui est un alias pour la fonction jQuery), celle-ci est exécutée au "domReady" ; c'est à dire lorsque le DOM (le HTML) de ta page a été chargé et interprété. Cet évènement survient avant le window.onload, qui lui est appelé lorsque tout est chargé (images, CSS etc...). Tu peux voir ça comme un window.onload optimisé.

    Plus d'infos ici : http://api.jquery.com/ready/

  3. #3
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2012
    Messages
    26
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Août 2012
    Messages : 26
    Par défaut
    Si ton code est inclus dans le head de ta page le code s'exécute à l'ouverture de ta page.
    > une bonne pratique serait d'inclure ton code dans des fichiers externes
    > une autre bonne pratique serait de faire appel à des gestionnaires d'événements: http://api.jquery.com/category/events/document-loading/

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    //s'exécute lorsque la page et ses éléments sont entièrement chargés
    $(window).load(function () {
      // code
    });
     
    //s'éxécute dès que la structure de la page et le fichier de script est chargé
    $(document).ready(function() {
      // code
    });
    Ces fonctions utilisent jQuery donc oui il est possible de les faire en pur javascript mais si tu bloques ici je ne te le conseille pas à moins que ce soit dans un but d'étude.

    Décortiquons:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    $(function () {
    $('#datetimepicker3').datetimepicker({
    pickDate: false,
    pickSeconds: false, // disables seconds in the time picker
    pick12HourFormat: false, // enables the 12-hour format time picker
    });
    });
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $(function () {
     
    });
    equivaut à:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    jQuery(function () {
     
    });
    équivaut à:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    jQuery('#datetimepicker3')
    c'est un selecteur qui va rechercher l'id datetimepicker3 dans la page et lorsqu'il le rencontre il lui applique la méthode:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    datetimepicker({
    pickDate: false,
    pickSeconds: false, // disables seconds in the time picker
    pick12HourFormat: false, // enables the 12-hour format time picker
    });
    dont on défini les variables pour ajuster les paramètres.

    Difficile de t'aider d'avantage, j'espère que tu y verras plus clair.
    N'hésite pas à mettre le nez dans la doc:
    http://api.jquery.com/
    http://jquery.developpeur-web2.com/documentation.php (FR)

  4. #4
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2013
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2013
    Messages : 13
    Par défaut
    C'est déjà plus clair !
    J'essaye de modifier ces fonctions demain.
    Je posterai le résultat du travail
    Merci !

  5. #5
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2013
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2013
    Messages : 13
    Par défaut
    A propos de l’exécution de ces fonctions, si j'ai bien comprit, elles s’exécutent qu'une seule fois (lors de la fin du chargement) ?
    Si c'est cas, comment peut on faire pour les rappeler ?
    J'ai un peu de mal avec la logique JQuery

  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
    Par défaut
    Facile, il suffit de déclarer la fonction et de l'appeler quand tu le souhaites

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    function test(){
    $('#datetimepicker3').datetimepicker({
    pickDate: false,
    pickSeconds: false, // disables seconds in the time picker
    pick12HourFormat: false, // enables the 12-hour format time picker
    });
    }
     
    test(); //exécuté immédiatement
     
    $(test); //exécuté au domready
     
    setTimeout(test, 10000); //exécuté après 10 secondes

  7. #7
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Si c'est cas, comment peut on faire pour les rappeler ?
    Ce que tu nous montres, ce sont des appels à des plugins jQuery, tu n'as normalement aucun besoin de les rappeler !
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

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