質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JSF

JSF (JavaServer Faces)とは、JavaベースのWebアプリケーションフレームワークの一つです。

Q&A

解決済

1回答

2287閲覧

JSFのresourceバージョニング対応の記述について

yoshi7

総合スコア48

JSF

JSF (JavaServer Faces)とは、JavaベースのWebアプリケーションフレームワークの一つです。

0グッド

0クリップ

投稿2016/06/06 07:41

バージョニングに対応してなかったので対応させたところ、
CSSリソース内の画像が表示されなくなり困っております。
正しい記述をご存知の方、ご教示をお願いします。
尚、当然ながら対応前はちゃんと表示されておりました。

■バージョニング対応前
resources
+-- css
| +-- common.css
+-- images
+-- icon.png

common.cssでの定義
background: url('../images/icon.png');

test.xhtmlでの定義
<h:outputStylesheet name="css/common.css"/>

■バージョニング対応後
resources
+-- default
+-- 1_0
+-- css
| +-- common.css
+-- images
+-- icon.png

common.cssでの定義
background: url("#{resource['default:images/icon.png']}");

test.xhtmlでの定義
<h:outputStylesheet library="default" name="css/common.css"/>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

以下のフォルダ配置と、CSS,xhtmlの記載でいかがでしょうか。
※imageもヴァージョニング対象とするよう書き直しました。

resources
+-- css
+--1_0
+-- common.css
+-- images
+-- icon.png

common.cssでの定義
background: url('images/icon.png');

test.xhtmlでの定義
<h:outputStylesheet library="css" name="common.css"/>


簡単に検証しましたので、結果を踏まえて追記します。
上記の方法では画像は表示できませんでした。表示させるには以下に配置変更が必要でした。

resources
+-- css
| +--1_0
| +-- common.css
+-- images
+-- icon.png

バージョニングによるcssファイル内のurl参照先の変更はできませんでした。画像を変更したいのであれば、imagesフォルダには別ファイル名(icon2.pngなど)で配置し、cssのurlはそのファイルを指すよう変更する用法になるかと思います。もっと最適な方法は有るかも知れませんが、調べ思い付いた範囲で回答させて頂きます。

投稿2016/06/06 08:22

編集2016/06/07 03:48
BlueMoon

総合スコア1339

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yoshi7

2016/06/06 09:06

回答ありがとうございます。 とても参考になりました。 imagesもバージョニング対象にする場合、 imagesフォルダはcssフォルダ内に入れるしか方法はないもんでしょうか? (cssから参照しない画像の方が多いので) imagesフォルダを2つに分けるしか方法はないのかな・・・。
BlueMoon

2016/06/06 09:13

cssファイルからの参照でかつバージョニング対象にしたいのであれば、ナンバリングフォルダ配下にするのかなと思います(2つに分ける)。混同を避けたいのであれば、ナンバリングフォルダ配下はフォルダ名を変更(img,commonImagesなど)されてはどうでしょうか。
yoshi7

2016/06/06 09:52

ありがとうございました。 フォルダを2つに分けて対処しようと思います。
yoshi7

2016/06/07 02:42

作業が立て込んでいて実装が今日になったんですが、 画像が表示されませんでした。 BlueMoonさんは表示されました?
BlueMoon

2016/06/07 02:58

参考書ベースで回答しましたので、実際に試していません。解答にその旨記載せず、失礼いたしました。
BlueMoon

2016/06/07 03:48

回答に追記しました。
yoshi7

2016/06/07 06:10

common.cssでの定義 background: url("#{resource['images:/icon.png']}"); 上記のようにすることで表示できました。 また、フォルダを2つ分けなくても良くなりました。 (cssフォルダ内にimgesフォルダを設けない)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問