Utilisation du pipeline d'actifs Rails 3.1 pour le chargement CSS conditionnel
Lors de la création d'applications Web avec Rails, il peut être nécessaire de restituer sélectivement les fichiers CSS en fonction de conditions spécifiques. Ceci peut être réalisé en utilisant le pipeline d'actifs Rails 3.1.
Par défaut, la commande *= require_tree dans application.css inclut tous les fichiers CSS dans le répertoire assets/stylesheets. Cependant, cela peut conduire à des résultats indésirables si vous souhaitez rendre les fichiers de manière conditionnelle.
Une solution de contournement consiste à spécifier manuellement chaque fichier CSS individuellement dans application.css et à utiliser un partiel pour inclure de manière conditionnelle les fichiers restants. Cependant, cette méthode peut devenir lourde et peu flexible.
Une solution plus efficace consiste à utiliser plusieurs fichiers manifestes pour séparer les fichiers CSS. En les organisant dans des répertoires pertinents et en créant des fichiers manifestes distincts pour chaque répertoire, vous pouvez facilement inclure ou exclure des fichiers en fonction de conditions spécifiques.
Voici un exemple de structure du répertoire d'actifs :
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
Et les fichiers manifestes correspondants :
/** * application-all.css * *= require_self *= require_tree ./all */ /** * application-print.css * *= require_self *= require_tree ./print */ /** * application-ie.css * *= require_self *= require_tree ./ie */
Enfin, mettez à jour la présentation de l'application file :
<%= 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\]-->
N'oubliez pas de précompiler les nouveaux fichiers manifestes dans config/environments/production.rb :
config.assets.precompile += %w( application-all.css application-print.css application-ie.css )
Notez que lorsque vous utilisez cette structure, vous devez vous assurer que toutes les références d'image dans vos fichiers CSS sont soit qualifiées avec le chemin complet, à l'aide de l'assistant SASS image-url(), soit déplacées pour suivre la même structure de répertoires.
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!