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

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

ただいまの
回答率

90.51%

  • HTML

    10736questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • CSS

    7011questions

    CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

アンカーリンク後に親要素のmarginが消えてしまいます。

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 1,392

kensay

score 2

タイトルの通りなのですが、ページ内のアンカーリンクを使用すると親要素のマージンが無効になってしまい困っています。(contents以下の要素が左に寄ってしまいます)
ページとしては左側に固定幅ナビゲーション、右側に可変幅コンテンツの2カラムデザインです。
初歩的な質問で恐縮ですが、ご教授願えればと思います。
#container {
    width: 100%;
    height: 100%;
}
#container #contents {
    width: 100%;
    height: 100%;
    margin-left: 140px;
    background: rgba(0, 0, 0, 0) url(images/image.jpg) no-repeat fixed center center/ cover;
    float: left;
}
#container #contents:after {
    content: "";
    clear: both;
    display: block;
}
#container #contents #title {
    width: 100%;
    height: 100%;
    min-height: 1080px;

}
#container #contents #title .titlelogo {
    top: 30%;
    left: 50%;
    position: absolute;
}
#container #contents #title #rect {
    margin: 100px auto 0;
    position: absolute;
    top: 80%;
    left: 51.5%;
}
・
・
・
以下子要素が続きます。

/*--ナビゲーション--*/
#pageNav {
    width: 120px;
    margin: 0;
    padding: 0 0 0 20px;
    height: 100%;
    background: #fff;
    position: fixed;
    float: left;
}
#pageNav:after {
    clear: both;
    display: block;
    content: "";
}
#pageNav li {
    margin: 0;
    top: 40%;
    width: 100%;
    position: relative;
}
#pageNav li a {
    display: inline-block;
    width: 80px;
    line-height: 40px;
    text-decoration: none;
    text-align: right;
    }
#pageNav li a img {
    margin: 0 0 5px 0;
}
無効になってしまうのは
#container #contents 内のmargin-leftです。
よろしくお願いいたします。

追記
検証したところ、clrome、Operaでは起こらずIEとFireFoxで起こる現象でした。
レンダリングエンジンンの問題なのでしょうか……。
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • takutok

    2015/06/16 12:17

    出来ればHTMLも見たいです。

    キャンセル

回答 1

+2

アンカーが…ではなくて、pageNavがfixedされてfloatしているので、contentsのwidthが100%なら画面幅一杯となります。
なのに、margin-leftに値があるので、画面からはみ出して横スクロールが生まれて、横スクロールするとcontentsがpageNavに隠れてしまう…←そのトリガーがアンカー?
ということでしょうか。

様々なアプローチがあるとは思いますが。。。

pageNavの固定位置が必須であるなら、floatやめて、pageNavの座標を設定し、contentsのmarginをpaddingにするとかでしょうか。


サンプルCSS(試してないので…すいません)
#container {
    width: 100%;
    height: 100%;
}
#container #contents {
    width: 100%;
    height: 100%;
    /* margin-left: 140px; ←下行の通りpaddingに変更 */ 
    padding-left:140px; /* ←追加 */
    background: rgba(0, 0, 0, 0) url(images/image.jpg) no-repeat fixed center center/ cover;
    /* float: left; ← 使用しないのでコメントアウト*/
}
/* ↓#container #contents:after はいらないかも。。。
#container #contents:after {
    content: "";
    clear: both;
    display: block;
}
*/
#container #contents #title {
    width: 100%;
    height: 100%;
    min-height: 1080px;

}
#container #contents #title .titlelogo {
    top: 30%;
    left: 50%;
    position: absolute;
}
#container #contents #title #rect {
    margin: 100px auto 0;
    position: absolute;
    top: 80%;
    left: 51.5%;
}
・
・
・
以下子要素が続きます。

/*--ナビゲーション--*/
#pageNav {
    width: 120px;
    margin: 0;
    padding: 0 0 0 20px;
    height: 100%;
    background: #fff;
    position: fixed;
    top:0; /* ←追加(最上部からの距離px) */
    left:0; /* ←追加(最左部からの距離px) */
    /* float: left; ← 使用しないのでコメントアウト*/
}
#pageNav:after {
    clear: both;
    display: block;
    content: "";
}
#pageNav li {
    margin: 0;
    top: 40%;
    width: 100%;
    position: relative;
}
#pageNav li a {
    display: inline-block;
    width: 80px;
    line-height: 40px;
    text-decoration: none;
    text-align: right;
    }
#pageNav li a img {
    margin: 0 0 5px 0;
}


投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/04/22 18:23

    ボックスモデルの概念、CSSの指定方法を見直した方が良いですね。

    #要素 #要素としなくてはいけない状況を避けた方が良いですよ。

    キャンセル

同じタグがついた質問を見る

  • HTML

    10736questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • CSS

    7011questions

    CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。