Help us understand the problem. What is going on with this article?

CSSで伝達アニメーション

More than 3 years have passed since last update.

sample1.gif

実際の動作を確認したい人向け
https://jsfiddle.net/junya_5102/hpxk1Lap/

作り方

  1. 要素を親子関係にします。
  2. 親と子に同じプロパティを指定、親に指定したプロパティの値は適当、子はinheritにします
  3. 子要素にtransitionを指定する

あとは 親要素のプロパティの値を変えれば伝達します

sample

HTML

<div class="root">
  <div>
    <div>
      <div>
        <div>
          <div>
            <div>
              <div>
                <div>
                  <div>
                    <div>
                      <div class="turn">
                        <div>
                          <div>
                            <div>
                              <div>
                                <div>
                                  <div class="turn">
                                    <div>
                                      <div>
                                        <div>
                                          <div>
                                            <div class="turn">
                                              <div>
                                                <div>
                                                  <div>
                                                    <div>
                                                      <div></div>
                                                    </div>
                                                  </div>
                                                </div>
                                              </div>
                                            </div>
                                          </div>
                                        </div>
                                      </div>
                                    </div>
                                  </div>
                                </div>
                              </div>
                            </div>
                          </div>
                        </div>
                      </div>
                    </div>
                  </div>
                </div>
              </div>
            </div>
          </div>
        </div>
      </div>
    </div>
  </div>
</div>

CSS

.root{
  position: absolute;
  width: 100px;
  height: 100px; 

  background-color: green;
  transform: scale(.5);
}

.root:hover{
   background-color: dodgerblue;
   border-radius: 100%;
}

.root div{
  position: absolute;
  top: 100%;
  left: 100%;

  width: 50px;
  height: 50px;

  /* inherit 親要素から継承 */
  border-radius: inherit;
  background-color: inherit;

  /* プロパティの値が変わったらアニメーションで変化 */
  transition: .2s;
}

.turn{
  transform: rotate(-90deg);
}

流れ

親(.root)にカーソルが乗ると 背景色をgreenからdodgerblue,角丸にします。

.root:hover{
   background-color: dodgerblue;
   border-radius: 100%;
}

子要素は 親の背景色と角丸を継承します

.root div{
  background-color: inherit;
  border-radius: inherit;
}

親にカーソルが乗ったとき、子に継承される値が変化します。
transitionを指定している場合は アニメーションで変化(遷移)します

.root div{
  transition: .2s;
}

親 -> 子 -> 孫 -> 曾孫 .... と継承されていきます。

animation & box-shadow

sample2.gif

※htmlは同じものを使用。

.root{
  position: absolute;

  width: 100px;
  height: 100px; 

  background-color: green;
  border-radius: 0;
  box-shadow: none;

  /* 位置・大きさ 調整 */
  top: 25%;
  left: 25%;
  transform: scale(.5) translate(-50%,-50%);

  animation: anim 1s linear infinite alternate;
}

.root div{
  position: absolute;
  top: 100%;
  left: 100%;

  width: 50px;
  height: 50px;

  /* inherit 親要素から継承 */
  border-radius: inherit;
  background-color: inherit;
  box-shadow: inherit;

  /* プロパティの値が変わったらアニメーションで変化 */
  transition: .2s;
}

.turn{
  transform: rotate(-90deg);
}

@keyframes anim{
  0%,49%{
    border-radius: 0;
    background-color: green;
    box-shadow: none;
  }

  50%,100%{
    border-radius: 100%;
    background-color: dodgerblue;
    box-shadow: 
      0 150px 0 0 crimson, 0 -150px 0 0 orange,
      -200px 150px 0 40px yellowgreen;
  }
}

ブラウザについて

Chrome,Safari は意図したとおりに動作

Firefoxはtransitionの仕様が異なる(?)ためアニメーションが動作しない。

Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away