Cet article analyse la solution au problème selon lequel TinyMCE ne peut pas obtenir de données lors de la soumission d'AjaxForm. Partagez-le avec tout le monde pour votre référence. L'analyse spécifique est la suivante :
Avant d'utiliser AjaxForm, j'ai créé un petit formulaire Web pour la soumission de commentaires. Le contenu des commentaires a été modifié à l'aide de TinyMCE. Afin d'améliorer un peu l'expérience utilisateur, utilisez simplement AjaxForm pour implémenter la soumission Ajax. Mais quelque chose d’inattendu s’est produit. Autrement dit, chaque fois que vous soumettez, la première fois que vous soumettez, AjaxForm ne pourra pas obtenir le contenu du commentaire actuellement modifié, c'est-à-dire le contenu de TextArea. Vous devez cliquer à nouveau sur Soumettre pour soumettre le contenu de TextArea.
La clé est que le contenu sur TinyMCE n'est pas mis à jour vers TextArea avant la soumission. Je voulais donc voir si AjaxForm avait une liaison d'événement avant la soumission. J'ai trouvé que dans l'événement beforeSubmit, le contenu de formData avait été rempli. Bien que je puisse remplir le contenu du TinyMCE actuel ici, j'ai toujours l'impression que ce n'est pas le cas. très jolie solution.
Afin de savoir s'il existe d'autres moyens de résoudre ce problème, j'ai vérifié le code source d'AjaxForm et j'ai découvert que l'auteur d'AjaxForm avait proposé une solution unifiée à ce problème. Le code source spécifique est le suivant :
1. Le code js est le suivant :
J'espère que cet article sera utile à la conception de la programmation JavaScript de chacun.