プロが教えるわが家の防犯対策術!

レスポンシブwebデザイン PCの背景とスマホの背景を別々に変更したいのですが、
どうやっても上手くいかない状況です。
どなたか解決できる方法をお教えくださませんでしょうか。

A 回答 (3件)

>Media QueriesにてCSSを振り分けています。


↑であれば、モニタの解像度でなら背景を変えることは可能です。
1つのcss内にメディアクエリで書き分けているのなら

/* PC用(大きなウインドウ用)*/
body{
background-image: url(../img/bg_pc.jpg);
}

@media screen and (max-width: 599px) {
/* スマホ用(幅が600px未満のウインドウ用)*/
body{
background-image: url(../img/bg_sp.jpg);
}
}
↑で表示されます。(将来的に解像度の大きなスマホが出てくる可能性も考慮して600pxをブレークポイントにしています。)
ただし、この方法はあくまでも【ウインドウの解像度】によって背景を変える方法ですので、PCでもウインドウを小さくしてみている場合はスマホ用の背景画像になります。


もしも、ウインドウのサイズにかかわらず、デバイスの種類で変更したいのであれば、
No1さんのおっしゃるようにユーザーエージェントを取得して、cssを書き換える方法がいいでしょう。
やはり先におっしゃられているとおり、ユーザーエージェントは膨大且つ複雑なので、将来にわたってすべての機種を思い通りに表示変更させるのは困難だということはご了承ください。
それでも現時点では、iPhoneか、iPadか、iPodか、andoroidか、それ以外(PC含む)か、位の判別は可能です。

【記入例その1】
ヘッダ末尾に以下を記入↓
<script type="text/javascript">
if (navigator.userAgent.indexOf('iPhone') > 0 || navigator.userAgent.indexOf('iPad') > 0 || navigator.userAgent.indexOf('iPod') > 0 || navigator.userAgent.indexOf('Android') > 0) {
document.write('<link rel="stylesheet" type="text/css" href="mobile.css" />');
}
</script>

PC用の背景は今まで使っていた指定。
スマホ用のcssとして読み込ませる"mobile.css"にスマホ用の背景を指定。

【記入例その2】
ヘッダ末尾に以下を記入。↓
<script type="text/javascript" src="jquery.jsへのリンク"></script>
<script type="text/javascript">
$(document).ready(function(){
if (navigator.userAgent.indexOf('iPhone') > 0) {
$('body').addClass('iPhone');
} else if (navigator.userAgent.indexOf('Android') > 0) {
$('body').addClass('Android');
}
});
</script>
↑上記によって、bodyにクラスがつきます。
cssに以下で指定。

/* PC用(クラスなし)*/
body{
background-image: url(../img/bg_pc.jpg);
}

/* iPhone用(ユーザーエージェントにiPhoneが含まれる場合)*/
body.iPhone {
background-image: url(../img/bg_iphne.jpg);
}

/*Android用(ユーザーエージェントにAndroidが含まれる場合)*/
body.Android {
background-image: url(../img/bg_android.jpg);
}

という感じでしょうか。

参考URL:http://blog.lqd.jp/webdesign/000173.html
    • good
    • 0
この回答へのお礼

ご丁寧な意見誠にありがとうございます。
本当に助かりました。

又の機会があればご指南のほど、宜しくお願いします。

お礼日時:2013/04/19 18:44

どうやったかわからないので的確な助言が難しいですが…。



Media Queriesでcssを振り分けてるんですか?
その場合、1つのcss内に
@media screen and (max-width: 600px) {...}
のように各ブレークポイントごとのcssを一緒に書いているのか、それとも
<link rel="stylesheet" media="screen and (max-width: 600px)" href="smartphone.css" />
のように、各ブレークポイントごとのcssを別のファイルに書いて、読み込みむものをhtmlで指定しているのか。

もしくはユーザーエージェントで振り分けるなど、Media Queries以外の方法を使っているのか。

そのあたりの情報がまったくないと、お答えのしようがないですね。。。
    • good
    • 0
この回答へのお礼

Media QueriesにてCSSを振り分けています。
この様な場合、PCとスマホの背景画像は切り替える事は出来るのでしょうか。
又、他のやり方はございますでしょうか。
宜しくお願いします。

お礼日時:2013/04/16 14:14

レスポンシブ・デザインの場合は、基本的には背景画像は切り替えません。


PC用とスマホ用と言う端末の種類で切り替えるためには、ユーザーエージェントによって画像を切り替える手法が別途必要になります。とても厄介です。ユーザーエージェントは膨大な種類がある上に、日々増え続けています。
 私は画像自体をCGIにしてユーザーエージェントで判別して出力する方法を使っています。技術的に誰でも出来る方法ではないので、普通は、メディアクエリを使ってウィンドウサイズだけで判断させるほうが良いでしょう。
 背景画像の使い方がわからないのですが、モダンブラウザ限定でbackground-sizeで背景画像を伸縮させ、特別狭いディスプレイ(スマホやPCでウィンドウ幅を小さくした場合)にはmediaqueryで、背景画像やフォントサイズを変更すると良いでしょう。もちろん、background-sizeやmediaqueryに対応していないブラウザに対する配慮も必要です。
基本1) ページはリキッドで作成する
基本2) floatは使わず絶対配置
基本3) 背景画像(内容と関係ない画像)はサイズが変わっても支障のないもの
基本4) コンテンツとして意味のある画像や、一部が切れてはまずい画像(背景も含む)は、imgでマークアップし、display:blockとして、親コンテナブロックのサイズを参照して伸縮させる。
基本5) スマホなどモダンブラウザにはmediaqueryでスタイルシートを切り替える。

ですかね。
    • good
    • 0
この回答へのお礼

とてもわかり易く、ご指南していただきまして、
誠にありがとうございます。
また機会があれば宜しくお願いします。
本当にありがとうございました。

お礼日時:2013/04/15 00:32

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!