見出し画像

JS Practice 03 Testimonial Slider

本記事で紹介すること

JSの練習第3弾として,Testimonial Sliderを実装する.
Testimonial Sliderとは,端的にいうとユーザレビューのことである.

3人ユーザレビューを用意し,数秒ごとに切り替わるものを実装しようと思う.
これまでとあまりやっていることは変わらないが,実装の際,分割代入を用いているところがこれまでになかったところである.

デザインの準備


今回は,CSSもちゃんと書こうと思い,数値も意識して厳密にFigmaで作成.

ユーザレビュー

起業家が出版した本のユーザレビューがwebサイトに記載されているイメージだ.


ユーザレビューを簡易に作成できないかを調べてみると,海外はAIを用いたTestimonial GeneretorのWebサービスが乱立している.日本でも同様のサービスがあるのかもしれないが,あまり見かけない.日本語サービスも,もしあれば,サンプル作る時に重宝できそうだ.(GPTsですぐにできそうである.)

参考)Free Testimonial Generetor

実装内容

例のごとく,Codepen問題は解決していないので,(調べる時間があまり取れない..)そのままコードを記載する

html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Testimonial</title>
    <link rel="stylesheet" href="style.css">
</head>
<body>
    <div class="testimonial-container">
       
        <h4 class="text">“この本は,新時代における起業家にとってのバイブルとなるだろう”</h4>
        <img src="https://images.unsplash.com/photo-1475823678248-624fc6f85785?q=80&w=1740&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D" alt="user image">
        <p class="username">山田ひろ子</p>
        <p class="company">株式会社ヤマダコンサルティング</p>
    </div>
    <script src="index.js"></script>
</body>
</html>

css

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;200;300;400;500;600;700;800;900&display=swap');

body {
    margin: 0;
    display: flex;
    justify-content: center;
    height: 100vh;
    align-items: center;
    background-color:#F7F4FF ;
}

.testimonial-container {
    width: 498px;
    height: 212px;
    background-color: #fff;
    border-radius: 10px;
    box-shadow: 0 7px 10px 6px rgba(0, 0, 0, 0.1);
    padding: 56px;
    text-align: center;
}

img {
    width: 56px;
    height: 56px;
    object-fit: cover;
    border-radius: 50%;
}

.text {
    color: #777676;
    font-size: 20px;
    font-weight: 400;
    margin-top: 0;
}
.username {
    color:#2D1AFF ;
    font-size: 16px;
    margin-top: 8px;
    margin: 8px;
}

.company {
    color: #777676;
    font-size: 16px;
    margin: 8px;
    
}

JS

//testimonialsのオブジェクト作成
const testimonials = [
    {
        name:"山田 ひろ子",
        photoUrl:"https://images.unsplash.com/photo-1475823678248-624fc6f85785?q=80&w=1740&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D",
        text:"“この本は,新時代における起業家にとってのバイブルとなるだろう”",
        company:"株式会社ヤマダコンサルティング",
    },
    {
        name:"廣岡 智之",
        photoUrl:"https://images.unsplash.com/photo-1544168190-79c17527004f?q=80&w=1588&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D",
        text:"“起業における重要なエッセンスが詰め込まれている”",
        company:"株式会社ベータトライ",
    },
    {
        name:"内田 美咲",
        photoUrl:"https://images.unsplash.com/photo-1515077678510-ce3bdf418862?q=80&w=1635&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D",
        text:"“サーキュラーエコノミーの実践者も必読.Z世代の起業家の起爆剤となる”",
        company:"ジアース4v株式会社"
    }
];


//クラスを取得するconst定数を定義
const imgEl = document.querySelector("img");
const textEl = document.querySelector(".text")
const usernameEl = document.querySelector(".username")
const companyEl = document.querySelector(".company")

//リスト内のインデックス番号
let idx = 0

//関数の実行
updateTestimonial()

//中身を更新する関数の定義
function updateTestimonial(){
    //testimonialsのプロパティの値を分割代入.これらを,前述のconst定数にわたす.
    const {name, photoUrl, text, company} = testimonials[idx];
    imgEl.src = photoUrl;
    textEl.innerText = text;
    usernameEl.innerText = name;
    companyEl.innerText = company;
    //インデックスを更新して次のuserに移動.
    idx++
    //インデックスが,testimonilasの最後まで来たら,インデックスを初期に戻す
    if(idx === testimonials.length){
        idx = 0;
    }
    
    setTimeout(updateTestimonial,2000)
}

最後に

上記を実装すると,
2秒ごとに,ユーザレビューが切り替わる形になっている.

というわけで,今回も学んだ内容をアウトプットした.

デザインをクイックに作成して,実装するのはなかなか大変ではあるが,勉強の過程で,様々なUI,Webデザインを観察する機会に恵まれるため良いトレーニングになる.

奥さんの協会のWebサイトを作る必要性に迫られて勉強を始めているので,そろそろ作らなきゃな..である.

いいなと思ったら応援しよう!