이 튜토리얼에서는 코딩 기초 학습에 적합한 실용적인 Random Quotes Generator 애플리케이션을 구축하는 과정을 안내합니다. 초보자도 쉽게 따라할 수 있도록 각 단계를 자세한 코드 예제로 설명하겠습니다.
사업개요
이 앱은 공개 API에서 임의의 인용문을 검색하여 표시하고 사용자가 이를 복사하거나 공유할 수 있도록 합니다. 프로세스를 세분화하고 코드 로직을 살펴보겠습니다.
1단계: HTML 구조
HTML 레이아웃을 만드는 것부터 시작합니다.
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Random Quotes Generator</title> <link rel="stylesheet" href="styles.css"> </head> <body> <div id="app"> <!-- Content will be added here --> </div> <script src="index.js"></script> </body> </html>
명언을 표시하는 요소, 새 인용문을 위한 버튼, 복사 및 공유를 위한 아이콘 등 기본 구조를 설정합니다.
2단계: 프록시를 사용한 CORS 처리
외부 API에 액세스하려면 CORS(Cross-Origin Resource Sharing) 솔루션이 필요합니다. 간단한 Express.js 프록시 서버가 이를 처리합니다.
// proxy.js const express = require("express"); const fetch = require("node-fetch"); const cors = require("cors"); const app = express(); app.use(cors()); app.get("/api/quote", async (req, res) => { try { const response = await fetch("https://qapi.vercel.app/api/random"); const data = await response.json(); res.json(data); } catch (error) { res.status(500).json({ error: "API fetch failed" }); } }); const PORT = 4000; app.listen(PORT, () => console.log(`Proxy running on http://localhost:${PORT}`));
이 로컬 프록시는 견적을 가져오고 CORS 문제를 방지합니다.
3단계: JavaScript로 견적 가져오기
"새 견적" 버튼을 누르면 견적 가져오기가 시작됩니다.
// index.js const quoteDisplay = document.getElementById("quote"); const authorDisplay = document.getElementById("author"); async function getQuote() { try { const response = await fetch('http://localhost:4000/api/quote'); const data = await response.json(); quoteDisplay.textContent = data.quote || "No quote found."; authorDisplay.textContent = data.author || "Unknown"; } catch (error) { console.error("Quote fetch error:", error); quoteDisplay.textContent = "Error fetching quote."; } }
이 스크립트는 데이터를 가져오고 UI에서 인용문과 작성자를 업데이트합니다.
4단계: 복사 기능
Clipboard API를 사용하면 견적 복사가 가능합니다.
// copyQuote.js async function copyQuote() { try { const quoteText = `${quoteDisplay.textContent} - ${authorDisplay.textContent}`; await navigator.clipboard.writeText(quoteText); alert("Copied to clipboard!"); } catch (error) { console.error("Copy failed:", error); } }
복사 아이콘을 클릭하면 인용문과 저자가 복사됩니다.
5단계: 기능 공유
Navigator API는 공유를 용이하게 합니다.
// shareQuote.js async function shareQuote() { const quoteText = `${quoteDisplay.textContent} - ${authorDisplay.textContent}`; try { await navigator.share({ text: quoteText }); } catch (error) { console.error("Share failed:", error); // Fallback for unsupported browsers alert(`Share this quote: ${quoteText}`); } }
이는 공유를 처리하고 navigator.share
부족한 브라우저에 대한 대체 기능을 제공합니다.
6단계: CSS를 사용한 스타일링
CSS는 시각적 매력과 반응성을 높이기 위해 앱 스타일을 지정합니다(간결함을 위해 스타일 예시는 생략됨).
7단계: 앱 실행
- 저장소 복제: (실제 저장소 URL로 교체)
-
종속성 설치:
npm install
-
프록시 서버 시작:
node proxy.js
- 브라우저에서
index.html
을 엽니다.
프로젝트 구조
-
index.html
: 메인 UI -
proxy.js
: CORS 프록시 서버 -
index.js
: 견적 가져오기 및 표시 -
copyQuote.js
: 복사 기능 -
shareQuote.js
: 공유 기능 -
styles.css
: 스타일링
API 크레딧
Quotes API에서 제공하는 인용문입니다.
결론
이 튜토리얼에서는 Random Quotes Generator 구축, API 통합, CORS 처리 및 브라우저 API를 시연하는 방법을 다뤘습니다. API 상호 작용, JavaScript 기본 사항 및 브라우저 API를 학습하기 위한 훌륭한 연습입니다. 피드백을 환영합니다!
깃허브 | 링크드인 | 엑스
위 내용은 무작위 인용 생성기 구축: 코드를 사용한 단계별 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

CSS 그리드는 복잡하고 반응이 좋은 웹 레이아웃을 만드는 강력한 도구입니다. 디자인을 단순화하고 접근성을 향상 시키며 이전 방법보다 더 많은 제어를 제공합니다.

기사는 반응 형 설계에서 공간의 효율적인 정렬 및 분포를위한 레이아웃 방법 인 CSS Flexbox에 대해 설명합니다. Flexbox 사용을 설명하고 CSS 그리드와 비교하고 브라우저 지원 세부 사항을 설명합니다.

이 기사는 Viewport Meta 태그, 유연한 그리드, 유체 미디어, 미디어 쿼리 및 상대 장치를 포함하여 CSS를 사용하여 반응 형 웹 사이트를 만드는 기술에 대해 설명합니다. 또한 CSS 그리드 및 Flexbox를 함께 사용하여 CSS 프레임 워크를 권장합니다.

이 기사는 요소 치수 계산 방법을 제어하는 CSS 박스 크기 속성에 대해 설명합니다. Content-Box, Border-Box 및 Padding-Box와 같은 값과 레이아웃 설계 및 형태 정렬에 미치는 영향을 설명합니다.

기사는 CSS, 주요 특성 및 JavaScript와 결합 된 애니메이션 작성에 대해 논의합니다. 주요 문제는 브라우저 호환성입니다.

기사는 3D 변환, 주요 속성, 브라우저 호환성 및 웹 프로젝트에 대한 성능 고려 사항에 대한 CSS 사용에 대해 논의합니다. (문자 수 : 159)

이 기사는 CSS 그라디언트 (선형, 방사형, 반복)를 사용하여 웹 사이트 비주얼을 향상시키고 깊이, 초점 및 현대적인 미학을 추가합니다.

기사는 CSS의 의사 요소, HTML 스타일을 향상시키는 데 사용 및 의사 급의 차이점에 대해 설명합니다. 실제 사례를 제공합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

WebStorm Mac 버전
유용한 JavaScript 개발 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전
