Maison > interface Web > js tutoriel > Comment puis-je déterminer l'état de préparation du DOM sans m'appuyer sur des frameworks ?

Comment puis-je déterminer l'état de préparation du DOM sans m'appuyer sur des frameworks ?

Susan Sarandon
Libérer: 2024-10-20 11:52:02
original
580 Les gens l'ont consulté

How Can I Determine DOM Readiness Without Relying on Frameworks?

Document.isReady : une solution native pour la détection DOM Ready

La dépendance à l'égard de frameworks comme Prototype et jQuery pour la gestion des événements window.onload peut ne pas toujours être désirable. Cet article explore des méthodes alternatives pour déterminer l'état de préparation du DOM, notamment grâce à l'utilisation de document.isReady.

Interrogation de Document.isReady

Pour les navigateurs modernes dotés d'API d'événements stables, le L'événement DOMContentLoaded fournit une méthode robuste pour gérer les événements prêts pour le DOM. Des implémentations comme celle-ci offrent une solution simple et efficace :

<code class="javascript">function fireOnReady() { /* ... */ }
if (document.readyState === 'complete') {
    fireOnReady();
} else {
    document.addEventListener("DOMContentLoaded", fireOnReady);
}</code>
Copier après la connexion

Propriété $.isReady de jQuery

jQuery propose une propriété non documentée, $.isReady, qui reflète le État prêt pour le DOM en interne. L'utilisation de cette propriété permet des contrôles concis :

<code class="javascript">if($.isReady) {
    // DOM is ready
} else {
    // DOM is not yet ready
}</code>
Copier après la connexion

Il est crucial de noter que cette propriété reste non documentée et que sa disponibilité dans les futures versions de jQuery ne peut être garantie. Utilisez-le avec prudence et préparez-vous aux changements potentiels lors des mises à niveau.

Un extrait de code DOM personnalisé

Pour une compatibilité plus large avec les navigateurs, un extrait de code DOM personnalisé peut être utilisé. Inspirée de l'approche de Dustin Diaz, elle vérifie le document.readyState à l'aide d'une expression régulière :

<code class="javascript">if( !/in/.test(document.readyState) ) {
    // document is ready
} else {
    // document is NOT ready
}</code>
Copier après la connexion

Cette méthode repose sur le fait que la sous-chaîne "in" est présente dans les champs "loading" et "interactive" ready états mais pas à l'état "complet".

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!

source:php
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal