J'ai un code JavaScript qui ajoute du nouveau XHTML à la page déjà existante (arborescence DOM). Mes éléments de page étant dynamiques, l'ajout de nouveaux éléments entraîne des modifications de la taille des autres éléments. J'ai une implémentation de barre de défilement personnalisée qui dépend de ces tailles et doit être réinitialisée chaque fois qu'ils changent.Détecter les modifications DOM du navigateur complet
J'appelle la méthode de réinitialisation peu de temps après l'instruction qui insère le nouveau XHTML. Mais il semble que c'est trop tôt. Parfois, la barre de défilement ne s'ajuste pas correctement. Si j'ajoute un peu de retard avant la réinitialisation, c'est OK, mais je le considère comme une solution trop grossière et peu fiable.
J'ai besoin soit:
Detect quand donné élément DOM changement de la taille, battant
ou
détecter quand l'ensemble du changement DOM se termine ainsi que la re-mise en page.
Jusqu'ici, je n'ai rien trouvé. Je sais que la situation est trop complexe pour la plupart des gens, mais j'espère que quelqu'un sera en mesure d'aider. Merci!
Je pense de cette manière que je ne ferai que comparer le contenu DOM et que je saurai quand il change, et ce avant que la mise en page se termine. J'ai déjà essayé DOMNodeInserted qui sert le même but, ça n'aide pas :( –
Mais vous avez un point, je pense à une certaine détection lorsque la hauteur de l'élément de défilement cible change réellement, parce que c'est ce qui m'intéresse. –
Oui, vous frapper le point avec le dernier edit. –