• ベストアンサー
※ ChatGPTを利用し、要約された質問です(原文:ローカルとWeb上で見え方が違うのですが…。)

ローカルとWeb上で見え方が違うのですが

このQ&Aのポイント
  • ローカルとWeb上で見え方が違うのですが…。 Webサイトを製作しているものです。質問したいのですが、ローカルとWeb上で見え方が違うことがあります。具体的には、IE系のブラウザでデザインが崩れてしまう現象が起きています。他のブラウザでは正常に表示されています。なぜ同じブラウザでもローカルとWeb上で見え方が違うのでしょうか?
  • 質問1: floatなしで要素を横に揃えることなんて無理ですよね? ファイルを修正してfloatを消してみた結果、段落が崩れてしまいました。floatを利用しない方法で要素を横に揃えることはできないのでしょうか?
  • 質問2: なぜ同じブラウザ(Sleipnir)でWeb上とローカルで見え方が違うのでしょうか? ローカルでは正常に表示されているにも関わらず、Web上ではデザインが崩れてしまい、特にIE系のブラウザで問題が起きています。なぜ同じブラウザでもローカルとWeb上で見え方が違うのでしょうか?

質問者が選んだベストアンサー

  • ベストアンサー
  • DrFell
  • ベストアンサー率55% (305/551)
回答No.6

>ページによっては左側、または右側の高さが一番高くなることがあるのですが、その場合の解決方法をご教示願えないでしょうか? 「高さを揃える css」で検索してみてください。私が先に挙げたカラムレイアウトの手法つまり、 float position table-cell のすべてで左右のみならず、3コラムになってどのコラムが高くなっても高さを揃えたり、そろえているように見せることが出来ます。table-cellが一番簡単ですがね。

nickname_1973
質問者

お礼

DrFellさん、 改めましてご回答ありがとうございます。現在もCSS切り替えで乗り切っている次第です。本当に時間が空きましたら改めて最初からやっていきたいと思います。 その時はお書き下さったアドバイスも参考にさせて頂きます。 ご回答ありがとうございました。

nickname_1973
質問者

補足

DrFellさん、 ご回答ありがとうございます。緊急避難としてIEとそれ以外でCSSを分けておきました。後ほど時間が空きましたら検索してやってみようとおもいます。 ありがとうございました。

全文を見る
すると、全ての回答が全文表示されます。

その他の回答 (5)

  • ORUKA1951
  • ベストアンサー率45% (5062/11036)
回答No.5

>ページによっては左側、または右側の高さが一番高くなることがあるのですが、その場合の解決方法をご教示願えないでしょうか? body>div.section{position:relative;}/* このdivの子孫要素の位置基準とするため */ div.section{background-color:silver;min-height:400px;}                     ^^^^^^^^^^^^^^^^^ 1) この最小高さを主文以外の高さの最大予想値よりも大きくしておく。 2) footerの巾を小さくして差し支えないようにする。 3) 常にもっとも長くなるものを基準にし、それ以外をabsoluteさせる。  こんなところかな・・・・ positionの長所は、 ★デザインのためにHTMLの構造が制約を受けない===>本来の文書構造を保てる ★デザインの制約が少ない と言うことでしょう。  なお、ウィンドウ巾の制約も受けませんから、様々な解像度(ウィンドウ巾)でも確認してください。

nickname_1973
質問者

お礼

ORUKA1951さん、 改めましてご回答ありがとうございました。一向に進まないので現在はCSSの切り替えで乗り切っております。後ろ向きの姿勢はいけないですが、しょうがありません。 大変お世話になりました。 またお世話になるかもしれませんが、その時はよろしくお願い致します。

nickname_1973
質問者

補足

ORUKA1951さん、 ご回答ありがとうございます。 緊急対策として、IEとそれ以外でCSSを分けてやりました。時間が空きましたらやらせていただきます。

全文を見る
すると、全ての回答が全文表示されます。
  • tracer
  • ベストアンサー率41% (255/621)
回答No.4

質問の趣旨とずれているかもしれませんが、段組(横並び)の方法として、positionとfloatで悩まれているのであれば、floatをおすすめします。段組の実装方法として、positionは汎用性が高いですが、初心者の方からすれば、実装の難易度はfloatよりもpositionの方が高いです。また、floatでしっかり組んであれば、ほとんどの場合、困ることはありません。floatで組みきれなかったといって、positionに逃げるのは、ちょっと違う気がします。 質問2は解決されているようなので、質問1だけにお答えします。数あるブラウザの中でもIEだけは特殊です。特殊というより間違った解釈をします。ご質問の内容も、IE(sleipnir)だけおかしいということなので、floatやpositionの前に、IEの挙動を理解することが解決策といえます。とはいえ、それほど難しいことはありません。たとえば以下のようなサイトの情報に目を通すだけでも十分ですよ。 http://css-bug.jp/win/ie/

nickname_1973
質問者

お礼

tracerさん、 ご回答ありがとうございます。floatがオススメなのですね。ご意見、考えてみます。 ご提示のサイト、見てみました。こんなにあるのですね。大変参考になりました。 本当にありがとうございました。

全文を見る
すると、全ての回答が全文表示されます。
  • DrFell
  • ベストアンサー率55% (305/551)
回答No.3

htmlを最初の段階できちっとしていればcssで表示場所を変えることは、できます。htmlをいじらなくても、cssで表現を変えるだけです。そのあたりhtml+cssの基本概念を理解してください。 5年以上前のサイトを紹介します。 http://blog.html.it/layoutgala/index.html 下の方に薄紫色の、htmlがあります。そのhtmlはその1つのみで変化しません。そしてcssをいじるだけで、40ほどのパターンのカラムレイアウトの紹介を上でされてます。htmlは変えなくても柔軟にレイアウトが変化することが可能であること、文章構造と見た目は分離して管理することを理解し、柔軟に対応できるhtmlを最初に組むことは大切であることもご理解ください。 今は当時よりさらに、プロパティが充実してきています。より簡単に多彩な表現が可能になっています。 「 ・3ペインの右側 ・3ペインの真ん中 ・3ペインの左側 と言う順序で書かれています。これを、 ・3ペインの左側 ・3ペインの真ん中 ・3ペインの右側 」 htmlを変えなくても、単純にcss でfloat:leftをfloat:rightじゃダメなの?と思ってしまいます。 横並びにさせるには、floatの他に、positionを使ったり、displayで表の様に扱うプロパティがよく使われます。floatを嫌いな人がいるように、positionはもたつきだすから嫌いって言う人もいますし、想定外になった場合、文字が重なるので嫌う人もいます。displayは対応ブラウザが新しいものに限るからちょっと……という人も。どれを選ぶかはもう少しいろいろと経験してからでもいい気がします。floatは横方向には柔軟ですが、縦方向には無力です。(後ろに書いたものを右や左に持ってくることはできるが、後述のものを前述のものより上に表示することはfloat1ではできない。) おっしゃっている症状下にいけない?はfloatが問題ではないです。他に問題があります。レンタルのスペースをつかっておられて、そこにアップすると自動で入る広告などの表現方法と、ローカルで作っておられる表現がぶつかってしまっている気がします。 position等を使ってレンタルスペース会社がサービス名や広告を固定配置させる時によくおきる症状に似ていますが、ソースがなければ憶測の域を超えません。どういうものを挿入されるのか知ってご自分のcssを組まないと作り直してもまた、崩れる可能性は大いにあります。自分の用意したhtmlとダウンロードしたhtmlでは変化があるはずです。比べてみてください。 そして、そのことは規約などで、了承しているからこそ、使える筈なのですが把握されていないのはまずいです。大切なことを読まずに承諾・契約されたのでしょうか? 横道、長文になってきましたので、この辺で

nickname_1973
質問者

お礼

DrFellさん、 ご回答ありがとうございます。ご紹介のサイト見ました。すごいと単純に思いました。 >>柔軟に対応できるhtmlを最初に組むことは大切であることもご理解ください。 痛み入ります。 ご回答、ありがとうございました。

全文を見る
すると、全ての回答が全文表示されます。
  • ORUKA1951
  • ベストアンサー率45% (5062/11036)
回答No.2

前の質問の続きということで・・・ 絶対配置にすると、記述の順番に依存しないのですから、ひっくり返せば、 ・3ペインの右側 ・3ペインの真ん中 ・3ペインの左側 であろうと ・3ペインの左側 ・3ペインの真ん中 ・3ペインの右側 であろうと、まったく関係ないことになります。 たとえば、 <body> _<div class="header"> __<h1>見出し</h1> _</div> _<div class="section"> __<div class="news"><!-- float時代の左--> ___<h2>新着情報</h2> ___<p>記事</p> __</div> __<div class="section"><!-- float時代の中央 --> ___<h2>本文見出し</h2> ___<p>記事</p> __</div> __<div class="tableContent"><!-- float時代の右 --> ___<h3>新着情報</h3> ___<ol> ____<li><a href="#top">ページトップへ</a></li> ____<li><a href="#section1">1章</a></li> ____<li><a href="#section2">2章</a></li> ___</ol> __</div> _</div> _<div class="footer"> __<h2>文書情報</h2> _</div> </body> (注)タブは_に置換してあります。 だったとしますが、position:absoluteだと、<div class="section">内のサブブロックがどのような順番で並んでいても、デザインは変化しません。 ★これが、文書構造が正しければどのようにも配置できる。 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ★デザインのために文書構造を変える必要がないという意味です。 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ★大事なことはHTMLが文書構造にしたがってきちんとかかれているかだけです。これさえできていれば、どのようにもデザインできます。  全体をborderで囲むときは<div class="article">ででも囲んでください。 下記CSSを一宣言ごとに記述して、表示の変化を確認してください。 HTMLは、 「HTMLで並べるテーブルに関して - HTML - 教えて!goo ( http://okwave.jp/qa/q7318537.html#a3 )」と同じです。 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html lang="ja"> <head> _<meta http-equiv="content-type" content="text/html; charset=Shift_JIS"> _<title>サンプル</title> _<meta name="author" content="ORUKA1951"> _<meta http-equiv="Content-Style-Type" content="text/css"> _<link rev="made" href="mailto:oruka1951@hoge.com" title="send a mail" > _<link rel="START" href="../index.html"> _<style type="text/css"> <!-- html,body{margin:0;padding:0;}/* おまじないを書いておきます */ body{background-color:gray;}/* わかりやすくするため背景に色を付けておきます。 */ h1,h2,h3,h4{margin:0;line-height:1.4em;}/* 見出しのmarginがはみ出すのを防ぐ */ /* これは、下のborderを消してみると効果がわかる */ div{border:solid 1px red;margin:0;}/* わかりやすくするためすべてのdivに枠線を引きます。 */ /* 同様にわかりやすくするため、それぞれのブロックに背景色を付けておきます。 */ div.header{background-color:aqua;min-height:100px;} div.section{background-color:silver;min-height:400px;} div.section div.section{background-color:white;min-height:0;} div.section div.tableContent{background-color:green;} div.footer{background-color:lime;min-height:100px;} /* ここまで、わかりやすくするため色・枠づけ・高さ--これをしておくとわかりやすいです。 */ /* ただし、borderのサイズだけそのブロックの外周サイズが大きくなっています */ /* 全体のサイズを決めます */ div.header,div.section,div.footer{ width:80%;min-width:640px;max-width:900px; margin:0 auto;/* ウィンドウの中央に */ } body>div.section{position:relative;}/* このdivの子孫要素の位置基準とするため */ div.section div.section{ min-width:0; /* 上での指定を消しておく */ width:auto; margin:0 20%;/* 左右に余白を開ける */ } div.section div.news, div.section div.tableContent{ position:absolute; /* 絶対配置を指定します。 */ height:100%; /* 高さは親要素の高さを参照します。(親がrelativeなので */ width:19%; top:0;/* 親要素の一番上 */ } div.section div.news{ right:0;/* 親要素の右 */ } div.section div.tableContent{ left:0;/* 親要素の左 上と入れ替えれば逆になる */ } --> _</style> </head> <body> _<div class="header"> __<h1>見出し</h1> __<div class="nav"> ___<ol> ____<li><a href="./">Top</a></li> ____<li><a href="./book">Books</a></li> ____<li><a href="./profile">Profile</a></li> ____<li><a href="./contact">Contact</a></li> ___</ol> __</div> _</div> _<div class="section"> __<div class="news"><!-- float時代の左--> ___<h2>新着情報</h2> ___<p>記事</p> __</div> __<div class="section"><!-- float時代の中央 --> ___<h2>本文見出し</h2> ___<p>記事</p> ___<h2>本文見出し</h2> ___<p>記事</p> ___<h2>本文見出し</h2> ___<p>記事</p> ___<h2>本文見出し</h2> ___<p>記事</p> __</div> __<div class="tableContent"><!-- float時代の右 --> ___<h3>新着情報</h3> ___<ol> ____<li><a href="#top">ページトップへ</a></li> ____<li><a href="#section1">1章</a></li> ____<li><a href="#section2">2章</a></li> ___</ol> __</div> _</div> _<div class="footer"> __<h2>文書情報</h2> _</div> </body> </html>

nickname_1973
質問者

補足

ORUKA1951さん、 ご回答ありがとうございます。floatなしでも出来るのですね。 今、サンプルをやっているのですが、ページによっては左側、または右側の高さが一番高くなることがあるのですが、その場合の解決方法をご教示願えないでしょうか?

全文を見る
すると、全ての回答が全文表示されます。
  • kmee
  • ベストアンサー率55% (1857/3366)
回答No.1

> 質問2: なぜ同じブラウザ(Sleipnir)でWeb上とローカルとで見え方が違うことがあるのでしょうか?(ファイルはもちろん同じ内容です。) Sleipnirに限定するなら ・ローカルでチェックしたときとWebでチェックしたときとで、レンダリングエンジンが違う (途中で変えたとか、サイト毎の設定があるとか) というのがありそうです。 御存じかもしれませんが、ブラウザ毎に見えかたが違うのは、最終的な「絵」を作る部分(レンダリングエンジン)が違うからです。 Sleipnirは、IEと同じエンジンと、Firefoxと同じエンジンを使っていて、切り替えできます。 IEのエンジンを使った時はIEと同じ表示になり、FIrefoxのエンジンを使えばFirefoxと同じ表示になります。 IEでは期待通りではなく、Firefox等では期待通り、だとすると、Sleipnirの設定がWebではIE,ローカルではFirefoxのエンジンを使ったのでないか、という予測ができます。

nickname_1973
質問者

お礼

kmeeさん、 ご回答ありがとうございます。Sleipnirがエンジンを替えることが出来るとは知っていたのですが、 >>WebではIE,ローカルではFirefoxのエンジン というのは知りませんでした。不勉強、申し訳ございません。 ググって発見してこようと思います。 ご回答、ありがとうございました。

全文を見る
すると、全ての回答が全文表示されます。

関連するQ&A

  • webサイトにある“QuickTimeMovie”をローカルに保存するには

    webサイトにある“QuickTimeMovie”をIE5でローカルにファイルとして保存するのには、どうしたら良いのでしょうか?わかる方、よろしくお願いします。

  • Webページをローカルに保存したい

    あるサイトのWebページをローカルに保存したいと思っています。 IEの「ファイル>名前を付けて保存」で ひとまず保存はできましたが、保存したファイルを開いたら 実際のWebの画面とはフォントなどが異なっていました。 Webの画面のイメージ通りに保存するために 何か良い方法はありますか? 実現するためのフリーソフトなどありましたら、教えてください。 よろしくお願いいたします。

  • webブラウザからローカルファイルの読み込み

    はじめまして、質問します。 webブラウザからローカルファイルの読み込みを行いたいのですが、 セキュリティーの問題でアクセスを拒否されました。 その回避法として、FileAPIによって htmlのinput要素かドラッグアンドドロップを用いて ローカルファイルを読み込めることが分かりました。 しかし、私がやりたいことは 絶対パスでローカルファイルを読み込むことです。 そのようなことは可能でしょうか? 上記の方法だとinputからフォルダをたどってファイルを選択するので 原理的には可能なような気がするのですが・・・・ 言語はjavascriptです。 よろしくお願いします。

  • ショートカットからWebページが開けなくなりました

    使用中のブラウザは「Sleipnir」です。 アドレスバーの左端にあるアイコンのショートカットからWebページを開いて利用していました。 昨日スパイウェアの削除を実行したところ、それまでできていたのにできなくなりました。 「ファイルを開くプログラムの選択」のウィンドウが開くので、「Sleipnir」を指定すると「…(ショートカットのパス)…は有効なwin32アプリケーションではありません」と表示されます。 {IE」を指定すると「IE」では開くことができるようになりましたが、メインのブラウザを「Sleipnir」に指定しなおしてもこちらでは開けません。 とりあえず削除前の状態に戻しましたが、改善できませんでした。 解決策をご存知の方、宜しくご指導ください。

  • 「履歴」にローカルのファイルも表示されるのがイヤ

    お世話になります。 これまで、Windows98+IE5.0の環境では、InternetExplorerの「履歴」に残るのは、InternetExplorerでアクセスしたWebサイトだったのですが、WindowsME+IE5.5環境にしてから、Explorerや一般のアプリケーションからアクセスしたローカルファイルまでも履歴に残るようになりました。 私は、履歴の「サイトを表示した回数順」「今日表示したページ順」などを重宝して利用していたので、ローカルファイルがここに入ってきて、一般のWebサイトの履歴をノックアウトしていくのが非常にいやなのです。 それだけならばまだいいのですが、FDのローカルファイルも履歴に残るので、「履歴」を表示するたびにFDにアクセスしにいって、うるさい&ハード的にもソフト的にもいらぬ負担がかかるため困っています。 どなたか、「履歴」にローカルファイルは残さない設定をご存じでしたらお教え下さい。

  • IEで画像が一部表示されない(ローカルでhtmlファイルを見る時)

    こんばんは。 Webサイトを作っているのですが、作ったページをローカルで見ようとすると画像が一部表示されず困っています。教えてgooでもよく「画像が表示されない」という質問があるのですが、今回はネットを接続している状態のことではなく、ローカルでの事で少し違うので新たに質問させていただきました。 状態は、 1.IEでだけ表示されない。(firefox、NNでは表示されます) 2.ほとんどの画像は表示されているのに、2つだけ表示されない 3.画像のアドレスなどは間違っていません(画像はdreamweaverで挿入し、ソースの確認もしました) 4.よく対処法として挙げられる、「ファイルの削除(全てのオフラインコンテンツを削除)」をやったのですが、その後該当のhtmlファイルを開くと1回目はきちんと表示され直ったと思ったものの、2回目からはまた出なくなりました。その後何回「ファイルの削除(全てのオフラインコンテンツを削除)」をやっても出ません。。 5.ちなみに、数日前に作った別のサイトはきちんと全部の画像が表示されます。 IEのキャッシュ関係が怪しいとは思っているのですが、一通り色々やってみても直らず困っています。 IEを一度アンインストールしてインストールしなおしたいのですが、コントロールパネルの「アプリケーションの追加と削除」でIEが無くてアンインストールできません。どうすればいいでしょうか?アドバイスお願いいたします。 また、もしこのまま直らなくても、そのサイトのファイル(htmlファイル+画像)をメールなどで添付して送った場合相手の方は問題なく見られるでしょうか? 私のIEがおかしいだけでしたら、大丈夫だとは思うのですが・・・ OSはwindows XP、IEは6.0です。

  • ウェブブラウザーの比較

    ウェブブラウザーには、 Internet Explorer Firefox Safari Opera Sleipnir Chrome とイロイロな種類がありますよね そこで質問なんですが 僕はIEを利用しています。 そしてホームページを作成しています。 自分が作成したホームページを他のウェブブラウザーで 見たらどんな風になっているか知りたいです。 知りたいからと言って  これらの種類を全部ダウンロードするのはチョット・・・ IEで見たらこんな感じ Firefoxで見たらこんな感じ Safariで見たらこんな感じ・・・ って判るようなツール的な物はありませんか? (もしくは、そんなサービスをしているページとか) よろしくお願いします。

  • ウェブメールから保存したファイルはどこへ?

    おはようございます。さっそく質問させて下さい! yahooウェブメールからファイルをダウンロードし”開く”で表示させた後に保存をしました。保存されたファイルはどこに行ったのでしょうか? 保存先を調べる為に何度か同じ事をして、どうやらローカルディスクC⇒DocumentandSetting⇒Local setting⇒temporary⇒contents内に保存している様なのですが、エクスプローラーでディスクC内を探しても見つける事ができません(>_<) 質問検索してみましたが、似た質問を見つける事ができず質問させて頂きました。どうか宜しくお願い致します。

  • 入れ子にしたfloatのclear

    初めてこちらを利用させていただきます。 CSSで縦3段、例えば上から『HEADER』、『MAIN』、『FOOTER』などとの段組を作成し、中央の『MAIN』内に『MENU』と『CONTENTS』の左右2段の段組をfloat:leftを利用して作成し、テンプレートとして利用しようとしています。 このテンプレート部分は、『MENU』の幅のみ固定で、『CONTENTS』は可変幅のレイアウトとしております。ここまでは順調に作成できたのですが、肝心のコンテンツの作成でつまづきました。 『CONTENTS』内に、更にfloat:leftで左右にDIVを配置したブロックを複数作ろうとした場合、2つ目のブロックを配置した時、1つ目の右側DIVの高さが1つ目左側DIVよりも高さが低い場合、2つ目以降のブロックが1つ目左側のDIV右に回りこんで表示されてしまいます。これは1つ目のブロックを配置した後、float:leftをclearしていないから当然だと思います。 そこで、1つ目のブロックの後にclearを摘要(<br />などに)させると、テンプレートの、『FOOTER』直上に2つ目のブロックが配置されてしまいます。1つのclearで入れ子になったfloat:leftが全てclearされてしまう様です。 これが『仕様』と言われればそれまでですが、TABLEや、固定幅のfloat:right等を使用すれば回避できそうですが、TABLE脱却・リキッドレイアウトをここまで実現できたのに、肝心のところで妥協するのも悔しい気がします。 まさか、こんな単純な事で丸一日悩むとは思いませんでした。web上を検索して回ったのですが、良い解決策が見つからず、こちらにおすがりした次第です。文章ではうまく表現できずわかりにくいかもしれませんが、何か回避作があれば教えて下さい。

    • ベストアンサー
    • CSS
  • ローカル画像を参照したい

    単純に、<body>の中に <img src="file:///D:/test.jpg alt="" /> というタグがあります。 このHTMLファイルは、Cドライブ直下に配置しています。 勿論、test.jpgもDドライブ直下に配置しています。 IEだと、このローカル画像を表示することができましたが、 Firefoxでは表示することができません。 原因が分かる方、ご教示いただけますでしょうか?

    • ベストアンサー
    • HTML