目录
项目概况
第 1 步:HTML 结构
第 2 步:使用代理处理 CORS
第 3 步:使用 JavaScript 获取报价
第 4 步:复制功能
第 5 步:共享功能
第 6 步:使用 CSS 设计样式
第 7 步:启动应用程序
项目结构
API 积分
结论
首页 web前端 css教程 构建随机报价生成器:带有代码的分步指南

构建随机报价生成器:带有代码的分步指南

Jan 22, 2025 am 04:46 AM

Building a Random Quotes Generator: A Step-by-Step Guide with Code

本教程将指导您构建实用的随机报价生成器应用程序,非常适合学习编码基础知识。 我们将用详细的代码示例来介绍每个步骤,使初学者可以轻松遵循。


项目概况

此应用程序从公共 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(跨源资源共享)解决方案。 一个简单的 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 步:复制功能

剪贴板 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 步:启动应用程序

  1. 克隆存储库:(替换为您的实际存储库 URL)
  2. 安装依赖项: npm install
  3. 启动代理服务器: node proxy.js
  4. 在浏览器中打开index.html

项目结构

  • index.html:主界面
  • proxy.js:CORS 代理服务器
  • index.js:报价获取并显示
  • copyQuote.js:复制功能
  • shareQuote.js:共享功能
  • styles.css:造型

API 积分

由 Quotes API 提供的报价。


结论

本教程涵盖了构建随机报价生成器、演示 API 集成、CORS 处理和浏览器 API。 对于学习 API 交互、JavaScript 基础知识和浏览器 API 来说,这是一个很好的练习。 欢迎反馈!

GitHub |领英 | X

以上是构建随机报价生成器:带有代码的分步指南的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

VUE 3 VUE 3 Apr 02, 2025 pm 06:32 PM

它的出局!恭喜Vue团队完成了完成,我知道这是一项巨大的努力,而且很长时间。所有新文档也是如此。

您可以从浏览器获得有效的CSS属性值吗? 您可以从浏览器获得有效的CSS属性值吗? Apr 02, 2025 pm 06:17 PM

我有人写了这个非常合法的问题。 Lea只是在博客上介绍了如何从浏览器中获得有效的CSS属性。那样的是这样。

在CI/CD上有点 在CI/CD上有点 Apr 02, 2025 pm 06:21 PM

我说的“网站”比“移动应用程序”更合适,但我喜欢Max Lynch的框架:

带有粘性定位的堆叠卡和一点点的杂物 带有粘性定位的堆叠卡和一点点的杂物 Apr 03, 2025 am 10:30 AM

前几天,我发现了科里·金尼文(Corey Ginnivan)网站上的这一点,当您滚动时,彼此之间的卡片堆放集。

在WordPress块编辑器中使用Markdown和本地化 在WordPress块编辑器中使用Markdown和本地化 Apr 02, 2025 am 04:27 AM

如果我们需要直接在WordPress编辑器中向用户显示文档,那么最佳方法是什么?

比较浏览器的响应式设计 比较浏览器的响应式设计 Apr 02, 2025 pm 06:25 PM

这些桌面应用程序中有许多目标是同时在不同的维度上显示您的网站。因此,例如,您可以写作

如何将CSS网格用于粘头和页脚 如何将CSS网格用于粘头和页脚 Apr 02, 2025 pm 06:29 PM

CSS网格是一系列属性的集合,旨在使布局比以往任何时候都容易。像任何东西一样,那里有一点学习曲线,但是网格是

Google字体可变字体 Google字体可变字体 Apr 09, 2025 am 10:42 AM

我看到Google字体推出了新设计(Tweet)。与上一次大型重新设计相比,这感觉更加迭代。我几乎无法分辨出区别

See all articles