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

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

ただいまの
回答率

88.78%

一部のHTMLだけ特定のcssの影響を受けないようにする

解決済

回答 5

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 856

renren643

score 246

サイトの大部分を決めるcss(例えばbodyなど)にcssがかかっていて基本的にはその通りしたいが、一部分だけそのcssの影響を受けないようにする、みたいな方法はありますか?

例えば以下のようにすると、基本的に全てのfontが100pxになってしまいますが、どうにかしてp.title-subだけはその影響を受けないようにしたいです。

<body>
  <h1 class="h1-main">h1-main</h1>
  <p class="title-main">title-main</p>
  <div class="exception">
    <p class="title-sub">title-sub</p>
  <div>
</body>
body{
  font-size: 100px;
}

しかもできれば、p.title-subだけには違うcssだけを当てたく、上記の例でいうと、「div.exception内にあるタグは全て特定の別のcssを優先的に割り当てる」というようなことは可能でしょうか?

ーーーーーーーーーーーーー追記ーーーーーーーーーーーーー
みなさん回答ありがとうございます。
今回やりたいことは、
「sample1.html,sample1.css」と「sample2.html,sample2.css」を合体するということなんですが、両者とも比較的たくさんコードがあり、「sample1.html,sample1.css」と「sample2.html,sample2.css」をそのまま(後ろにくっつけただけでは)「もともとのsample1.html,sample1.css」と「もともとのsample2.html,sample2.css」の純粋な合体ver、ではなく、「sample1.html,sample1.css」のcssのいくつかの点が「sample2.html,sample2.css」に影響を与えてしまっている、という状況のコードが出来上がってしまいます。
これを簡単に解決し、「もともとのsample1.html,sample1.css」と「もともとのsample2.html,sample2.css」の純粋な合体ver、を作りたいのですが可能でしょうか?
(sample2.htmlはsample2.cssの内容だけを参照し、,sample1.cssの内容は一切参照しないということ)

もちろん、そのために全てのcssを書き換えるということで解消するのですが、もっと簡単な方法はないのかと思いまして。。。
わかりにくくてすみません。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • m.ts10806

    2019/05/11 11:54

    回答はしていますが、後だしがひどすぎるので本件には今後一切関わりません。

    キャンセル

回答 5

+4

CSSは!importantが宣言されていない限り、基本的には後勝ちなので、「別の指定」を「後」に書けば良いです。
クラスを指定しているのでできればタグまでつけて親子関係も含めて指定したいですね。

body{
  font-size: 100px;
}
div.exception p.title-sub{
  font-size: 20px;
}

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/05/10 22:19

    概説として書かれているのでしょうけれど、詳細度の関係で後勝ちとはならない場合があるので、質問者がそのように覚えてしまうと後々ハマってしまうかも……

    キャンセル

  • 2019/05/10 22:21

    ご指摘ありがとうございます。いつも「基本的には」をつけるのですが失念しておりました。
    太字で追記しておきました。

    キャンセル

  • 2019/05/10 22:22

    加筆ありがとうございます。細かい話をしてすみません。

    キャンセル

  • 2019/05/10 22:24

    いえ、「今回はそこまで細かい指定するわけじゃないからいっか」という甘えが頭の隅っこにあったせいだと思います。助かりました。

    キャンセル

checkベストアンサー

+1

とにかく簡単に、ということであれば

  • sample1.htmlとsample2.htmlをiframeタグで描画する
  • それぞれのcssのクラス名にプリフィックスやサフィックスをつけて、全部違うセレクタにしてしまう(セレクタがclassだけであればですが)

などでしょうか。
バッティングしないように、cssのクラス名の付け方などの設計を見直すのがより良いとは思います。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

+1

こういうことでしょうか?

div.exception *{
  font-size:16px; /* サイズを指定したい場合 */
  font-size:initial; /* デフォルトに戻したい場合 */
}
質問の変更を受けて追記
<div id="sample1">
ここにsample1.htmlの部分
</div>
<div id="sample2">
ここにsample2.htmlの部分
</div>
#sample1{
ここにsample1.css
}
#sample2{
ここにsample2.css
}


とすれば、そこそこ上手くいくんじゃないかな、などと思うのですが……

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/05/10 22:59

    ちなみにinitialはIE11で使用できないので
    PCサイトの場合は注意が必要です。
    https://developer.mozilla.org/ja/docs/Web/CSS/initial

    キャンセル

  • 2019/05/10 23:16

    回答ありがとうございます。
    確かにサイズだけならそれで解消すると思うのですが、、、
    質問を追記したので、そちらも見ていただけると大変ありがたいです。。。

    キャンセル

  • 2019/05/10 23:30

    追記は最初に記載するべきでしたね。
    SCSSやnpmを使用すれば可能です。
    > 純粋な合体ver、を作りたいのですが可能でしょうか?

    キャンセル

+1

CSSのスコープ

CSSはCSSを宣言したのと同じDOMツリー上の全ての要素に影響します。
従って、ご質問の例であれば、通常はセレクタを2つ作成して、適用範囲を分割します。

:not(p.title-sub) {
  font-size: 100px;
}

p.title-sub {
  font-size: 200px;
}

shadow DOM

shadow DOMは、DOMツリー上から隠れたDOMですので、CSSの適用範囲外となります。

<!DOCTYPE html>
<title>shadow DOM</title>
<style>
body {
  font-size: 20px;
}

p {
  color: red;
  font-weight: bold;
}
</style>
<p>normal content 1</p>
<div id="exception"></div>
<p>normal content 2</p>


<template id="shadow-template"><style>
* {
  font-size: initial;
}
</style>
<p>shadow content</p></template>
<script>
'use strict';
const shadowContents = document.importNode(document.getElementById('shadow-template').content, true);
const shadowRoot = document.getElementById('exception').attachShadow({mode: 'closed'});

shadowRoot.appendChild(shadowContents);
</script>

Google Chrome 74.0.3729.131 はshadow DOMに継承プロパティを継承してしまうらしく、継承プロパティを initial で初期値に戻しています。
Firefox 66.0.5にはこの問題はありません。

Google Chrome 74.0.3729.131 には、リセットCSSの要領で、継承プロパティを initial で初期化し直す対策をとれば、問題を回避できるでしょう。 
少々強引ですが、全てをshadow DOMにしてスタイルを分割する方法もあります。

Re: renren643 さん

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

基本的に、ブラウザそのものがデフォルトスタイルを持っていますので、影響を全く受けないようには出来ません。そのためにリセットCSSが存在します。

また、そのページ内において、例えば、body以外の影響を受けたくなければ、body以下の要素と同階層(兄弟要素)に置けば、body以外のCSSは継承されません。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

  • ただいまの回答率 88.78%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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