Endlich habe ich ein paar Workarounds / Lösungen ausgearbeitet.
1) Von Ссылка sieht es aus, als könnte das in Sass-Rails behoben werden. Ich habe Helfer geplappert. Ich richte mich nach dem vorgeschlagenen Patch im obigen Link. Ich habe einfach die erforderliche Umgebungsvariable in der Asset-Vorkompilierungszeile in %code% festgelegt.
Ich mache alle meine Affe-Patches in einer einzigen Datei %code% . In dieser Datei habe ich diese Methode wie folgt gepatcht:
%Vor%2) Wenn Sie Bilder in das CSS einbetten möchten, ändern Sie das Stylesheet mit der Erweiterung .erb und ersetzen Sie %code% durch %code% , ohne dass sass-rails geändert werden müssen. %code% existiert nicht als reine Sass-Funktion, daher müssen Sie den Rails-Helfer %code% verwenden.
In den neuesten Rails 3.1.3 müssen Sie jetzt ein anderes Modul installieren, damit es funktioniert
Das habe ich gemacht
%Vor%Und in meinem deploy.rb habe ich:
%Vor%Ich bin dabei, eine Rails 3-App zu aktualisieren, um Rails 3.1 zu verwenden, und benutze dabei die neue Asset-Pipeline. Bis jetzt habe ich alles außer einem ziemlich nervigen Problem, das ich nicht lösen kann.
Die Anwendung und alle ihre Assets funktionieren in der Entwicklung gut, aber in der Produktion wird sie mit Passenger ( %code% ) in einen Sub-URI deployed. Das Problem dabei ist, dass die Assets während der Bereitstellung vorkompiliert werden und eine meiner CSS-Dateien (nun, es ist eine %code% -Datei) den %code% -Helfer aus dem %code% -Element nutzt. Da die Pfade während der Vorkompilierung in der vorkompilierten CSS-Datei fest codiert sind, wird die Sub-URI nicht berücksichtigt:
In meiner %code% Datei:
%Vor%Das Ergebnis in der kompilierten %code% -Datei:
%Vor%Was sollte es sein, damit es richtig funktioniert:
%Vor%Ist dieses Szenario nur zu viel verlangt? Wenn das der Fall ist, muss ich auf den alten, nicht auf Assets basierenden Weg zurückwechseln und meine Bilder und CSS nur von %code% aus bedienen. Es scheint jedoch etwas zu sein, über das nachgedacht und gelöst werden sollte ...? Fehle ich die Lösung?
Edit 1: Ich sollte das mit der Erb-Lösung liefert stattdessen das gleiche Ergebnis, wie man es erwarten würde.
Edit 2: als Antwort auf Benoit Garrets Kommentar
Nein, das Problem hängt nicht mit %code% zusammen. Ich habe versucht, dies zu setzen (auf %code% anstatt auf den Standardwert %code% ), aber es stellte sich heraus, dass das falsch war - es scheint, dass diese Einstellung bereits mit dem Stamm der Rails-App zusammenhängt, nicht mit dem Server . Das zu entfernen (und somit zum Standard zurückzukehren) hat all die seltsamen Probleme behoben, die verursacht haben (und es gab viele, alle Assets wurden in %code% gelandet - es war alles sehr seltsam). Das einzige Problem ist, dass die %code% Helfer und Freunde den Sub-URI nicht übernehmen, wenn sie vorkompiliert sind. Unnötig zu sagen, dass dies logisch ist, da es, wenn es vorkompiliert ist, nicht wissen kann, dass es, wenn es unter Passenger läuft, auf diese Weise konfiguriert wird. Meine Frage ist, wie ich es darüber informieren soll und damit die richtigen Pfade im vorkompilierten Ergebnis erhalten. Wenn es tatsächlich möglich ist.
Meine aktuelle Problemumgehung besteht darin, die CSS-Datei wie folgt zu referenzieren: %code% und in den nicht-pipelinierten Speicherort %code% zu platzieren. Kaum ideal, da es nicht vom Fingerabdruck und allem, was die Pipeline bietet, profitiert.
Nachdem ich ein bisschen gegraben habe, habe ich das Problem gefunden. Das Problem tritt in Rails auf, insbesondere in Ritzels :: Helpers :: RailsHelper :: AssetPaths # compute_public_path. Rinkets :: Helpers :: RailsHelper :: AssetPaths erbt von ActionView :: AssetPaths und überschreibt eine Reihe von Methoden. Wenn compute_public_path über die Methode sass :: Rails :: Resolver # public_path aufgerufen wird, ist der racks rack helper die Aufgabe, das Asset aufzulösen. Rippets :: Helpers :: RailsHelper :: AssetPaths # compute_public_path wird auf Super verteilt, was ActionView :: AssetPaths # compute_public_path ist. In dieser Methode gibt es eine Bedingung von has_request? auf rewrite_relative_url_root wie unten zu sehen:
%Vor%Wenn Sie sich die Interna von rewrite_relative_url_root ansehen, hängt es von einer Anforderung ab, dass sie vorhanden ist, und der Fähigkeit, sie von der Controller-Variablen abzuleiten, um den relativen URL-Root aufzulösen. Das Problem ist, dass wenn Rakete diese Ressourcen für Sass auflöst, es keinen Controller vorhanden hat und daher keine Anfrage.
Die obige Lösung funktionierte für mich im Entwicklungsmodus nicht. Hier ist die Lösung, die ich verwende, um es für jetzt zu arbeiten:
%Vor%Ich verwende Rails 3.1.3 und setze erfolgreich einen Sub-URI ein. Ich habe nichts gepatcht.
Die Hauptprobleme bei diesem Setup wurden hier besser besprochen. Wie Sie sehen können, wurde die Lösung auf Rails 3.2 angewendet und niemals nach 3.1.4 zurückgeliefert.
Aber ich bin zu einer Lösung gekommen, die Rails 3.1.3 verwendet, die für meine Einrichtung funktioniert.
Probieren Sie Folgendes aus: (Ich bin kein Experte, versuche nur einen Beitrag zur Lösung eines Problems zu leisten, das mich stundenlang belästigt hat ...)
environment.rb:
%Vor%production.rb:
%Vor%routes.rb:
%Vor%Wie Sie sehen können, habe ich assets.prefix in production.rb und nicht in application.rb abgelegt Danach tun Sie:
%Vor%und als, Test mit der Konsole:
%Vor%Ergebnisse:
%Vor%Ich bin dabei, eine Rails 3-App zu aktualisieren, um Rails 3.1 zu verwenden, und benutze dabei die neue Asset-Pipeline. Bis jetzt habe ich alles außer einem ziemlich nervigen Problem, das ich nicht lösen kann.
Die Anwendung und alle ihre Assets funktionieren in der Entwicklung gut, aber in der Produktion wird sie mit Passenger ( http://the-host/sub-uri/
) in einen Sub-URI deployed. Das Problem dabei ist, dass die Assets während der Bereitstellung vorkompiliert werden und eine meiner CSS-Dateien (nun, es ist eine .css.scss
-Datei) den image-url
-Helfer aus dem sass-rails
-Element nutzt. Da die Pfade während der Vorkompilierung in der vorkompilierten CSS-Datei fest codiert sind, wird die Sub-URI nicht berücksichtigt:
In meiner .css.scss
Datei:
Das Ergebnis in der kompilierten application-<md5-hash-here>.css
-Datei:
Was sollte es sein, damit es richtig funktioniert:
%Vor% Ist dieses Szenario nur zu viel verlangt? Wenn das der Fall ist, muss ich auf den alten, nicht auf Assets basierenden Weg zurückwechseln und meine Bilder und CSS nur von public
aus bedienen. Es scheint jedoch etwas zu sein, über das nachgedacht und gelöst werden sollte ...? Fehle ich die Lösung?
Edit 1: Ich sollte das mit der Erb-Lösung liefert stattdessen das gleiche Ergebnis, wie man es erwarten würde.
Edit 2: als Antwort auf Benoit Garrets Kommentar
Nein, das Problem hängt nicht mit config.assets.prefix
zusammen. Ich habe versucht, dies zu setzen (auf /sub-uri/assets
anstatt auf den Standardwert /assets
), aber es stellte sich heraus, dass das falsch war - es scheint, dass diese Einstellung bereits mit dem Stamm der Rails-App zusammenhängt, nicht mit dem Server . Das zu entfernen (und somit zum Standard zurückzukehren) hat all die seltsamen Probleme behoben, die verursacht haben (und es gab viele, alle Assets wurden in /sub-uri/sub-uri/assets
gelandet - es war alles sehr seltsam). Das einzige Problem ist, dass die image-url
Helfer und Freunde den Sub-URI nicht übernehmen, wenn sie vorkompiliert sind. Unnötig zu sagen, dass dies logisch ist, da es, wenn es vorkompiliert ist, nicht wissen kann, dass es, wenn es unter Passenger läuft, auf diese Weise konfiguriert wird. Meine Frage ist, wie ich es darüber informieren soll und damit die richtigen Pfade im vorkompilierten Ergebnis erhalten. Wenn es tatsächlich möglich ist.
Meine aktuelle Problemumgehung besteht darin, die CSS-Datei wie folgt zu referenzieren: url(../images/bg.png)
und in den nicht-pipelinierten Speicherort public/images
zu platzieren. Kaum ideal, da es nicht vom Fingerabdruck und allem, was die Pipeline bietet, profitiert.
Endlich habe ich ein paar Workarounds / Lösungen ausgearbeitet.
1) Von Ссылка sieht es aus, als könnte das in Sass-Rails behoben werden. Ich habe Helfer geplappert. Ich richte mich nach dem vorgeschlagenen Patch im obigen Link. Ich habe einfach die erforderliche Umgebungsvariable in der Asset-Vorkompilierungszeile in deploy.rb
festgelegt.
Ich mache alle meine Affe-Patches in einer einzigen Datei config/initializers/gem_patches.rb
. In dieser Datei habe ich diese Methode wie folgt gepatcht:
2) Wenn Sie Bilder in das CSS einbetten möchten, ändern Sie das Stylesheet mit der Erweiterung .erb und ersetzen Sie image-url("bg.png")
durch url(<%= asset_data_uri "bg.png" %>)
, ohne dass sass-rails geändert werden müssen. asset-data-uri
existiert nicht als reine Sass-Funktion, daher müssen Sie den Rails-Helfer asset_data_uri
verwenden.
Ich verwende Rails 3.1.3 und setze erfolgreich einen Sub-URI ein. Ich habe nichts gepatcht.
Die Hauptprobleme bei diesem Setup wurden hier besser besprochen. Wie Sie sehen können, wurde die Lösung auf Rails 3.2 angewendet und niemals nach 3.1.4 zurückgeliefert.
Aber ich bin zu einer Lösung gekommen, die Rails 3.1.3 verwendet, die für meine Einrichtung funktioniert.
Probieren Sie Folgendes aus: (Ich bin kein Experte, versuche nur einen Beitrag zur Lösung eines Problems zu leisten, das mich stundenlang belästigt hat ...)
environment.rb:
%Vor%production.rb:
%Vor%routes.rb:
%Vor%Wie Sie sehen können, habe ich assets.prefix in production.rb und nicht in application.rb abgelegt Danach tun Sie:
%Vor%und als, Test mit der Konsole:
%Vor%Ergebnisse:
%Vor%Nachdem ich ein bisschen gegraben habe, habe ich das Problem gefunden. Das Problem tritt in Rails auf, insbesondere in Ritzels :: Helpers :: RailsHelper :: AssetPaths # compute_public_path. Rinkets :: Helpers :: RailsHelper :: AssetPaths erbt von ActionView :: AssetPaths und überschreibt eine Reihe von Methoden. Wenn compute_public_path über die Methode sass :: Rails :: Resolver # public_path aufgerufen wird, ist der racks rack helper die Aufgabe, das Asset aufzulösen. Rippets :: Helpers :: RailsHelper :: AssetPaths # compute_public_path wird auf Super verteilt, was ActionView :: AssetPaths # compute_public_path ist. In dieser Methode gibt es eine Bedingung von has_request? auf rewrite_relative_url_root wie unten zu sehen:
%Vor%Wenn Sie sich die Interna von rewrite_relative_url_root ansehen, hängt es von einer Anforderung ab, dass sie vorhanden ist, und der Fähigkeit, sie von der Controller-Variablen abzuleiten, um den relativen URL-Root aufzulösen. Das Problem ist, dass wenn Rakete diese Ressourcen für Sass auflöst, es keinen Controller vorhanden hat und daher keine Anfrage.
Die obige Lösung funktionierte für mich im Entwicklungsmodus nicht. Hier ist die Lösung, die ich verwende, um es für jetzt zu arbeiten:
%Vor%Tags und Links ruby-on-rails-3.1 asset-pipeline assets passenger sprockets