Maison > interface Web > tutoriel CSS > Comment puis-je implémenter l'inclusion CSS conditionnelle dans Rails 3.1 à l'aide de Sprockets ?

Comment puis-je implémenter l'inclusion CSS conditionnelle dans Rails 3.1 à l'aide de Sprockets ?

Barbara Streisand
Libérer: 2024-11-27 06:32:10
original
989 Les gens l'ont consulté

How Can I Implement Conditional CSS Inclusion in Rails 3.1 Using Sprockets?

Inclusion conditionnelle d'actifs dans Rails 3.1 avec Sprockets

Dans la quête d'optimisation du rendu CSS, de nombreux développeurs ont du mal à relever le défi de l'inclusion sélective de CSS fichiers basés sur des conditions spécifiques. Ce problème devient pertinent lorsqu'il s'agit de mises en page réactives ou d'assurer la compatibilité entre les navigateurs.

Dans Rails 3.1, le pipeline d'actifs fournit un mécanisme puissant pour gérer les actifs statiques. Par défaut, la commande *= require_tree dans application.css inclut tous les fichiers du répertoire assets/stylesheets. Cependant, cette approche peut ne pas suffire pour inclure conditionnellement des fichiers CSS.

Une solution traditionnelle mais maladroite

Une solution de contournement consiste à spécifier manuellement chaque fichier CSS, comme illustré :

*= require_self
*= require home.css
...
*= require blueprint/screen.css
Copier après la connexion

Bien que cette méthode fonctionne, elle devient moins pratique à mesure que le nombre de fichiers CSS augmente.

Exploiter des manifestes séparés et des dossiers organisés

Une solution plus élégante consiste à réorganiser le dossier actifs/feuilles de style et à utiliser des fichiers manifestes distincts :

app/assets/stylesheets
+-- all
    +-- your_base_stylesheet.css
+-- print
    +-- blueprint
        +-- print.css
    +-- your_print_stylesheet.css
+-- ie
    +-- blueprint
        + ie.css
    +-- your_ie_hacks.css
+-- application-all.css
+-- application-print.css
+-- application-ie.css
Copier après la connexion

Chaque catégorie obtient son propre fichier manifeste :

/* application-all.css */
*= require_self
*= require_tree ./all

/* application-print.css */
*= require_self
*= require_tree ./print

/* application-ie.css */
*= require_self
*= require_tree ./ie
Copier après la connexion

Le fichier de mise en page de l'application est mis à jour en conséquence :

<%= stylesheet_link_tag "application-all", :media => "all" %>
<%= stylesheet_link_tag "application-print", :media => "print" %>

<!--[if lte IE 8]>
    <%= stylesheet_link_tag "application-ie", :media => "all" %>
<![endif]-->
Copier après la connexion

N'oubliez pas d'inclure les fichiers manifestes dans config/environments/production.rb :

config.assets.precompile += %w( application-all.css application-print.css application-ie.css )
Copier après la connexion

Références d'images

Avec cette structure, la prudence est de mise lorsqu'il s'agit de références d'images. Une solution potentielle consiste à déplacer les images en conséquence, garantissant ainsi une organisation cohérente avec les fichiers CSS. Alternativement, on peut choisir de qualifier le chemin de l'image ou d'utiliser l'assistant SASS pour les URL des images.

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.cn
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