Détection d'événements pour les modifications de propriétés CSS avec jQuery
Dans le domaine du développement Web, la détection des modifications des propriétés CSS d'un élément peut être crucial pour la mise en œuvre de mises à jour dynamiques. Avec jQuery, vous pouvez exploiter la puissance des événements DOM pour surveiller et répondre efficacement aux modifications des propriétés CSS telles que « display ».
Utilisation de DOMAttrModified Event
Modern les navigateurs prennent en charge les événements de mutation DOM, qui incluent l'événement DOMAttrModified. Cet événement est spécifiquement conçu pour vous avertir lorsque les attributs d'un élément sont modifiés, y compris les propriétés CSS définies en ligne ou via des feuilles de style externes.
Pour exploiter l'événement DOMAttrModified, vous pouvez utiliser l'événement DOMAttrModified de jQuery. &&&]on()
, comme démontré ci-dessous :document.documentElement.addEventListener('DOMAttrModified', function(e){
if (e.attrName === 'style') {
console.log('prevValue: ' e.prevValue, 'newValue: ' e.newValue);
}
}, false);
document.documentElement.style.display = 'block';
document.documentElement.addEventListener('DOMAttrModified', function(e){
if (e.attrName === 'style') {
console.log('prevValue : ' e.prevValue, 'newValue : ' e.newValue);
}
}, FAUX);
document.documentElement.style.display = 'block';Dans cet exemple, nous attachons un écouteur d'événement à l'élément document.documentElement
, qui représente la racine du document. Lorsqu'un attribut de style (tel que "display") est modifié, ce gestionnaire d'événements est déclenché, vous permettant d'accéder aux valeurs précédentes et actuelles de l'attribut modifié.Exploiter l'événement "propertychange" d'IE
&&&]Pour les navigateurs plus anciens qui ne prennent pas en charge DOMAttrModified, vous pouvez utiliser l'événement propriétaire "propertychange"
d'Internet Explorer comme solution de secours. Bien que cet événement soit spécifiquement pris en charge par IE, il peut fournir une méthode fiable pour détecter les changements de style dans ces environnements.Pour utiliser l'événement "propertychange", vous pouvez utiliser l'événement de jQuery. fonction on()
avec un argument de chaîne, comme le montre l'exemple suivant :document.documentElement.addEventListener('DOMAttrModified', function(e){
if (e.attrName === 'style') {
console.log('prevValue: ' e.prevValue, 'newValue: ' e.newValue);
}
}, false);
document.documentElement.style.display = 'block';
document.documentElement.on('propertychange', function(e){
if (e.propertyName === 'affichage') {
console.log('prevValue : ' e.prevValue, 'newValue : ' e.newValue);
}
}, FAUX);
document.documentElement.style.display = 'block';Note sur les observateurs de mutations
Bien que les techniques susmentionnées étaient des approches courantes pour détecter les changements de propriétés CSS dans le passé, les navigateurs les plus récents recommandent d'utiliser Mutation Observers, qui fournit un mécanisme plus standardisé et rationalisé pour surveiller les modifications d'éléments DOM spécifiques.Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3