0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

年末まで毎日webサイトを作り続ける大学生 〜10日目 Css Grid Layout, Flex Box, Google Font, jsで名言をランダムに表示してみた〜

Posted at

はじめに

初めまして。
年末まで毎日webサイトを作っている者です。
今日もMDNの初心者ページを見て勉強していたんですが、そういえばレイアウト全然やってないなということでGrid Layout, Flex Boxを使ってみました。
作ったものはGrid Layoutの枠に入ると名言がランダムで表示されるというものです。
JavaScriptも簡単ではありますが使っています。
扱う技術レベルは低いですが、同じように悩んでる初心者の方を勇気付けられれば幸いです。
今日は10日目。(2019/10/28)
よろしくお願いします。

サイトURL

やったこと

まずは、どんなものが出来上がったのかgifでどうぞ! ↓
test.gif

全体の構成と、カーソルが乗ると色が変わる部分をGrid Layoutで実装しています。
Grid Layoutを使うとhtmlがほとんど汚れません (これでhtml部分全て) ↓

<h2 id="header">Css Grid Layout</h2>
    <nav id="nav">
        <span id="rule">7 RULES</span>
        <ol id="rule_text">
            <li>enjoy!</li>
            <li>relax!</li>
            <li>fun!</li>
            <li>eat!</li>
            <li>you can do it!</li>
            <li>yes!</li>
            <li>happy!</li>
        </ol>
    </nav>
    <div id="main">
        <div id="box1"></div>
        <div id="box2"></div>
        <div id="box3"></div>
        <div id="box4"></div>
        <div id="box5"></div>
        <div id="box6"></div>
        <div id="box7"></div>
        <div id="box8"></div>
        <div id="box9"></div>
    </div>
    <footer id="footer">
        All Rights Reserved.
    </footer>

全体の構成を調整するcss部分↓


body {
            display: grid;
       /* ↓ここで縦方向を制御しています */
            grid-template-rows: 100px 1fr 100px;
       /* ↓ここで横方向を制御しています */
            grid-template-columns: 200px 1fr;
        }

rowsの100px 1fr 100pxというのは、縦に3つのブロックがあって上下が100px、真ん中は余った分全部のスペースを使うという意味です。
columnsの200px 1frは横に2つのブロックがあって左端が200px、1frは残り余った部分を使います。

ではカーソルが変わると色が変わる部分を見ていきましょう。htmlはこの部分が該当します↓


<div id="main">
        <div id="box1"></div>
        <div id="box2"></div>
        <div id="box3"></div>
        <div id="box4"></div>
        <div id="box5"></div>
        <div id="box6"></div>
        <div id="box7"></div>
        <div id="box8"></div>
        <div id="box9"></div>
    </div>

css ↓ (他にやり方がわからず長くなってしまいました・・・)

# main {
/*全体構成の中で#main自体をどこに配置するかの指定↓ */
            grid-column: 2 / 3;
            grid-row: 2 / 3;

/* #mainのなかのdivたちをどう構成するかの指定↓ */
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            grid-template-rows: repeat(3, 1fr);
        }
# box1 {
            grid-column: 1 / 2;
            grid-row: 1 / 2;
        }

        #box2 {
            grid-column: 2/ 3;
            grid-row: 1 / 2;
        }

        #box3 {
            grid-column: 3 / 4;
            grid-row: 1 / 2;
        }

        #box4 {
            grid-column: 1 / 2;
            grid-row: 2 / 3;
        }

        #box5 {
            grid-column: 2 / 3;
            grid-row: 2 / 3;
        }

        #box6 {
            grid-column: 3 / 4;
            grid-row: 2 / 3;
        }

        #box7 {
            grid-column: 1 / 2;
            grid-row: 3 / 4;
        }

        #box8 {
            grid-column: 2 / 3;
            grid-row: 3 / 4;
        }

        #box9 {
            grid-column: 3 / 4;
            grid-row: 3 / 4;
        }

grid-template-columns: repeat(3, 1fr); 

これは1frを3回繰り返すという意味です。columnsなので横に1frが3つ、つまり3ブロックは均等に1/3ずつの大きさが割り当てられます。

そしてJavaScript・・・。これはあまり見せたくないのですが・・・↓



    <script>
        let box1 = document.getElementById('box1');
        let box2 = document.getElementById('box2');
        let box3 = document.getElementById('box3');
        let box4 = document.getElementById('box4');
        let box5 = document.getElementById('box5');
        let box6 = document.getElementById('box6');
        let box7 = document.getElementById('box7');
        let box8 = document.getElementById('box8');
        let box9 = document.getElementById('box9');

        box1.addEventListener('mouseover', meigenGo);
        box2.addEventListener('mouseover', meigenGo);
        box3.addEventListener('mouseover', meigenGo);
        box4.addEventListener('mouseover', meigenGo);
        box5.addEventListener('mouseover', meigenGo);
        box6.addEventListener('mouseover', meigenGo);
        box7.addEventListener('mouseover', meigenGo);
        box8.addEventListener('mouseover', meigenGo);
        box9.addEventListener('mouseover', meigenGo);

        box1.addEventListener('mouseleave', meigenGoAway);
        box2.addEventListener('mouseleave', meigenGoAway);
        box3.addEventListener('mouseleave', meigenGoAway);
        box4.addEventListener('mouseleave', meigenGoAway);
        box5.addEventListener('mouseleave', meigenGoAway);
        box6.addEventListener('mouseleave', meigenGoAway);
        box7.addEventListener('mouseleave', meigenGoAway);
        box8.addEventListener('mouseleave', meigenGoAway);
        box9.addEventListener('mouseleave', meigenGoAway);


        let meigen = [
            'Think rich, look poor.',
            'One of these days is none of these days.',
            'Believe and act as if it were impossible to fail.',
            'If you obey all the rules, you miss all the fun.',
            '努めて難関を歩いて、努めて苦労を味わう。これが人間としては、大切なことである。',
            '人は忙しい中にも静かにくつろぐような心を持たなくてはならないし、苦しみの中にあっても、そこに楽しみを見出す工夫をしなければならない。',
            '人を信じよ、しかし、その百倍も自らを信じよ。'
        ];

        let count = 0;

        function meigenGoAway(e) {
            let eventTarget = e.target;
            let rgb = randomRGB();
            let r = rgb[0];
            let g = rgb[1];
            let b = rgb[2];
            eventTarget.style.backgroundColor = 'rgba(' + r + ', ' + g + ',' + b + ', .5)';
            eventTarget.textContent = "";

        }

        function meigenGo(e) {
            let randomNumber = Math.floor(Math.random() * meigen.length);
            let choiceMeigen = meigen[randomNumber];
            let eventTarget = e.target;
            eventTarget.style.backgroundColor = 'rgba(255, 255, 255, .7)';
            eventTarget.textContent = choiceMeigen;
            count += 1;
            if (count >= 50) {
                alert('欲張るのか!');
            }
        }

        function randomRGB() {
            let r = Math.floor(Math.random() * 256);
            let g = Math.floor(Math.random() * 256);
            let b = Math.floor(Math.random() * 256);
            let rgb = [r, g, b];
            return rgb;
        }

    </script>

はい、怒涛のgetElementByIdとaddEventListenerです・・・。
どうやればスマートに書けるのか思案中です。

let meigen

これは名言を格納しておく配列です。

関数 meigenGoは、名言の配列の長さを使ってランダムに名言を1つ選び、それをtextContentでdivに入れ込むということをやっています。あとはbackgroundcolorを白にして文字を読みやすくするのと、50回以上名言が表示されたら「欲張るのか!」というアラートを出します。

次に関数 meigenGoAwayですが、これはカーソルがdivから離れた時に、meigenGoで背景色を白にしていたのを他の色にしています。ランダムな値はrandomRGB 関数から受け取っています。あとここでdiv内の名言を消しています。

最後にFlex BoxとGoogle Fontを紹介します。
Flex Boxはナビで使っています(ナビはしませんが) ↓


# nav { 
            display: flex;
/* 縦に要素を配置する指示↓ */
            flex-direction: column;
/* 要素を左右中央に寄せる指示↓ */
            justify-content: center;
/* Google Fontのコード↓ */
            font-family: 'Liu Jian Mao Cao', cursive;
        }

そしてGoogle Fontはheadのところでlinkを読み込んでいます ↓


<link href="https://fonts.googleapis.com/css?family=Stoke&display=swap" rel="stylesheet">
<link href="https://fonts.googleapis.com/css?family=Liu+Jian+Mao+Cao&display=swap" rel="stylesheet">

感想

Grid Layoutはとても便利だと思いました。Flex Boxも簡単に要素の配置が調整できて嬉しいです。以前floatとかいうのを使ったことがありますがそれとは段違いの使いやすさでした。
ちなみにMDNはやっぱりいいサイトですね。ありがとうございます。

--

最後までお読みいただきありがとうございます。
明日も頑張ります!

参考・引用

  1. CSS Grid Layout を極める!(基礎編)(https://qiita.com/kura07/items/e633b35e33e43240d363)

今日はたくさんのサイトにお世話になりました。ありがとうございます!

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?