Analyse CSS en JavaScript / jQuery
Dans cet article, nous approfondirons le problème de l'analyse CSS en JavaScript, en nous concentrant spécifiquement sur la tâche de transformer le code CSS en une représentation basée sur des objets. Nous explorerons les limites d'une implémentation DIY et présenterons une solution potentielle utilisant CSSOM.
Implémentation DIY et ses défis
L'extrait de code fourni tente d'analyser CSS manuellement , diviser les règles en points-virgules et en accolades. Cependant, cette approche ne suffit pas lorsqu'on rencontre des propriétés CSS avec des points-virgules incorporés, telles que les URL d'arrière-plan.
Une approche alternative : utiliser CSSOM
Pour surmonter ces défis, nous pouvons exploitez le modèle d’objet CSS (CSSOM) intégré au navigateur. CSSOM nous permet d'accéder et de manipuler les règles CSS de manière dynamique. Nous pouvons utiliser cette fonctionnalité à des fins d'analyse.
Implémentation à l'aide de CSSOM
Le code JavaScript suivant montre comment utiliser CSSOM pour analyser CSS :
var rulesForCssText = function (styleContent) { var doc = document.implementation.createHTMLDocument(""), styleElement = document.createElement("style"); styleElement.textContent = styleContent; // the style will only be parsed once it is added to a document doc.body.appendChild(styleElement); return styleElement.sheet.cssRules; };
Pour chaque règle renvoyée par RulesForCssText, nous pouvons inspecter ses propriétés en utilisant Rule.style.
Exemple d'utilisation
Pour illustrer l'utilisation de cette approche, considérons le JavaScript Fiddle suivant (https://jsfiddle.net/v2JsZ/) :
var css = "a { color: red; }"; var rules = rulesForCssText(css); console.log(rules[0].selectorText); // "a" console.log(rules[0].style.color); // "red"
Conclusion
Pendant l'analyse manuelle de CSS en JavaScript est possible, cela introduit des pièges potentiels. En tirant parti de CSSOM, nous pouvons exploiter les capacités du navigateur pour une analyse CSS fiable et efficace.
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!