Maison > interface Web > js tutoriel > le corps du texte

js simule un événement de clic

一个新手
Libérer: 2017-09-25 09:53:57
original
5251 Les gens l'ont consulté

Une fois la page chargée, nous rencontrons souvent des problèmes de liaison. À ce stade, il est nécessaire de déclencher automatiquement le premier événement de clic après le chargement de la page afin que les liens suivants puissent être affichés sur la page Web.
Vous pouvez utiliser la
méthode trigger dans js

$("selector").trigger("click");
Copier après la connexion

Par exemple, dans mon code, j'ai d'abord ajouté un événement click au li dans l'ul, puis simulé le déclenchement de cet événement.

    $(".place-classify ul").on("click","li",function(){
        var placeName = $(this).html();
       createPlaceContent(placeName) ;
    });
    $(".place-classify ul li:first-child").trigger('click');
Copier après la connexion

Mais parfois l'événement de simulation ne se déclenche pas. Généralement, vous pouvez rencontrer deux problèmes :

  1. L'événement de clic de simulation est écrit devant l'événement de clic. .
    Certaines personnes pensent que cela se déclenche après le chargement de la page, surtout si elle est écrite en $(function(){});, elle est d'abord rendue puis déclenchée. Cependant, lorsqu'une page est ouverte, les éléments de la page entière sont rendus. d'abord, pas le code js, le code js Il sera toujours exécuté un par un, donc si le clic simulé est écrit devant, il sera d'abord déclenché puis déclaré, il n'aura donc aucun effet, déplacez-le simplement vers l'arrière. de l'événement de clic.

  2. L'événement click a été déplacé vers l'arrière mais toujours pas déclenché, cela peut donc être dû à un chargement asynchrone. Puisque votre page Web est chargée de manière asynchrone, cela se produira car les données ont été téléchargées. n'a pas encore été traité. L'événement Click est déclenché de la même manière avant la génération des éléments générés dynamiquement. La solution consiste à remplacer la requête ajax par une requête synchrone. $.ajax({ <code>$.ajax({ <br>        url:url, <br>        data:data, <br>        async:false, <br>        success:function(result){ <br>            handle(result); <br>        }, <br>        error:function(result){ <br>            alert("获取数据失败"); <br>        } <br>    }); URL:url,

    données:données,
  3. async: faux,
Succès :fonction(résultat){             handle(résultat); }, Erreur :fonction (résultat){ alert("Échec de l'obtention des données");       } });

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal