날씨앱

Noh Sinyoung·2023년 6월 14일
0
<!DOCTYPE html>
<html lang="ko">
<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>Document</title>

    <link rel="stylesheet" href="0517 날씨앱.css">

</head>
<body>
    <div class="container">
        <header class="header">
            <h1>전 세계 날씨 검색</h1>
            <select name="" id="">
                <option value="seoul">서울</option>
                <option value="osaka">오사카</option>
                <option value="fukuoka">후쿠오카</option>
                <option value="venezia">베네치아</option>
                <option value="busan">부산</option>
                <option value="new york">뉴욕</option>
            </select>
        </header>

        <div class="main">
            <h3 class="region">서울 중구</h3>
            <p class="temp"><span>30</span>&deg;C</p>
            <img class="icon" src="" width="80px" alt="날씨아이콘">
            <div class="detail">
                <span class="feel">체감온도<span>0</span>&deg;C</span>
                <span class="wind">풍속<span>0</span>m/s</span>
            </div>
        </div>

    </div>

    <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
    <script>
        const KEY = "47c44037a668e7569c5d4687b724255e"
        const 도시이름 = document.querySelector(".region")
        const 기온 = document.querySelector(".temp span")
        const 체감온도 = document.querySelector(".feel span")
        const 풍속 = document.querySelector(".wind span")
        const 이미지 = document.querySelector(".icon")

        //디폴트
        axios.get(`https://api.openweathermap.org/data/2.5/weather?q=seoul&appid=${KEY}`)
        .then(function (response) {
            // 성공 핸들링
            console.log(response);

            도시이름.innerHTML = response.data.name
            기온.innerHTML = (response.data.main.temp - 273).toFixed(1)
            체감온도.innerHTML = (response.data.main.feels_like - 273).toFixed(1)
            풍속.innerHTML = response.data.wind.speed
            이미지.setAttribute("src", `https://openweathermap.org/img/wn/${response.data.weather[0].icon}@2x.png`)

            console.log("도시 이름", response.data.name)
            console.log("기온", response.data.main.temp)
            console.log("체감온도", response.data.main.feels_like)
            console.log("풍속", response.data.wind.speed)
        })

        //let API = `https://api.openweathermap.org/data/2.5/weather?q=${city}&appid=${KEY}`
    
        const 셀렉 = document.querySelector("select")
        셀렉.addEventListener("change", (e) => {
            console.log(e)
            // e.target.value에 option의 value가 들어있음

            axios.get(`https://api.openweathermap.org/data/2.5/weather?q=${e.target.value}&appid=${KEY}`)
            .then(function (response) {
                // 성공 핸들링
                console.log(response);

                도시이름.innerHTML = response.data.name
                기온.innerHTML = (response.data.main.temp - 273).toFixed(1)
                체감온도.innerHTML = (response.data.main.feels_like - 273).toFixed(1)
                풍속.innerHTML = response.data.wind.speed
                이미지.setAttribute("src", `https://openweathermap.org/img/wn/${response.data.weather[0].icon}@2x.png`)

                console.log("도시 이름", response.data.name)
                console.log("기온", response.data.main.temp)
                console.log("체감온도", response.data.main.feels_like)
                console.log("풍속", response.data.wind.speed)
            })
            .catch(function (error) {
                // 에러 핸들링
                console.log(error);
            })
        })
 

    </script>


</body>
</html>

==================================================================================================

* {margin: 0; padding: 0;}

/* 이 부분은 상단 메뉴 부분 */

.header {
    background-color: rgb(80, 140, 218);
    display: flex; justify-content: space-between;
    padding: 20px;
}

h1 {
    color: rgb(255, 255, 255);
}

select {
    width: 200px;
}

.main {
    position: relative; top: 400px;
    display: flex; justify-content: center; align-items: center;
    flex-direction: column;
}

.region {
    font-size: 40pt; color: darkcyan;
}
.temp span {font-size: 60pt;}
.temp {
    font-size: 30pt;
}

.detail {
    display: flex;
}

.detail > span {
    background-color: deepskyblue; color: white;
    border-radius: 8px; padding: 5px; margin: 10px;
}

0개의 댓글