本教程将指导您构建实用的随机报价生成器应用程序,非常适合学习编码基础知识。 我们将用详细的代码示例来介绍每个步骤,使初学者可以轻松遵循。
此应用程序从公共 API 检索随机报价,显示它们,并允许用户复制或共享它们。 我们来分解一下流程,探究一下代码逻辑。
我们首先创建 HTML 布局:
<code class="language-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></code>
这设置了基本结构,包括显示报价的元素、新报价的按钮以及用于复制和共享的图标。
为了访问外部API,我们需要一个CORS(跨源资源共享)解决方案。 一个简单的 Express.js 代理服务器可以处理这个问题:
<code class="language-javascript">// 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}`));</code>
此本地代理获取报价并避免 CORS 问题。
“新报价”按钮会触发报价获取:
<code class="language-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."; } }</code>
此脚本获取数据,更新 UI 中的引用和作者。
剪贴板 API 支持复制报价:
<code class="language-javascript">// 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); } }</code>
单击复制图标可复制引用和作者。
Navigator API 促进共享:
<code class="language-javascript">// 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}`); } }</code>
这处理共享,为缺少navigator.share
的浏览器提供后备。
CSS 样式应用程序以提高视觉吸引力和响应能力(为简洁起见,省略了示例样式)。
npm install
node proxy.js
index.html
。index.html
:主界面proxy.js
:CORS 代理服务器index.js
:报价获取并显示copyQuote.js
:复制功能shareQuote.js
:共享功能styles.css
:造型由 Quotes API 提供的报价。
本教程涵盖了构建随机报价生成器、演示 API 集成、CORS 处理和浏览器 API。 对于学习 API 交互、JavaScript 基础知识和浏览器 API 来说,这是一个很好的练习。 欢迎反馈!
GitHub |领英 | X
以上是构建随机报价生成器:带有代码的分步指南的详细内容。更多信息请关注PHP中文网其他相关文章!