full-stack-foundations

full-stack-foundations

掌握全栈Web开发的核心基础

Full Stack Foundations 工作坊通过实际项目开发,教授Web应用构建的核心概念和技能。课程涵盖JavaScript、TypeScript、React和Node.js等关键技术,让学员掌握全栈开发基础和现代Web开发最佳实践。

全栈开发Web应用JavaScriptTypeScriptReactGithub开源项目
<div> <h1 align="center"><a href="https://www.epicweb.dev/workshops/full-stack-foundations">🔭 全栈基础</a></h1> <strong> 学习构建Web应用程序的基础工具和技能 </strong> <p> 在本工作坊中,我们将通过一个真实世界的应用程序中的练习,帮助你学习构建Web应用程序的一些关键概念。 </p> </div> <div align="center"> <a alt="Epic Web标志及'已部署版本'字样" href="https://foundations.epicweb.dev/" > <img width="300px" src="https://github-production-user-asset-6210df.s3.amazonaws.com/1500684/254000390-447a3559-e7b9-4918-947a-1b326d239771.png" /> </a> </div> <hr /> <!-- prettier-ignore-start -->

构建状态 GPL 3.0 许可证 行为准则

<!-- prettier-ignore-end -->

先决条件

系统要求

  • git v2.18或更高版本
  • NodeJS v20或更高版本
  • npm v8或更高版本

所有这些都必须在你的PATH中可用。要验证是否正确设置,你可以运行以下命令:

git --version node --version npm --version

如果你在任何一项上遇到问题,可以了解更多关于PATH环境变量的信息,以及如何在WindowsMac/Linux上修复它。

设置

这是一个相当大的项目(实际上是多个应用程序合一),因此第一次设置可能需要几分钟时间。请确保网络连接良好,然后再运行设置,并准备一些小吃。

按照以下步骤进行设置:

git clone --depth 1 https://github.com/epicweb-dev/full-stack-foundations.git cd full-stack-foundations npm run setup

如果你在此过程中遇到错误,请提出问题并提供尽可能多的详细信息。

练习

你可以在exercises目录中找到所有练习。下面描述了工作坊应用程序的结构,但大多数时候,你应该能够简单地运行应用程序,并使用应用程序导航不同的练习(甚至有按钮可以直接在你的编辑器中打开正确的练习文件)。

练习的目的不是让你自己完成所有的材料。它的目的是让你的大脑思考在_我_讲解材料时要问我的正确问题。

运行应用程序

要启动并运行应用程序(并真正看看它是否正常工作),请运行:

npm start

现在打开浏览器,访问为你记录的地址,你就可以开始了!

运行测试

package.json中的测试脚本会对解决方案运行测试(这些测试应该都能通过)。要对你自己的工作运行测试,只需打开问题页面并点击"Test"标签。

启动你的编辑器

应用程序有几个按钮,可以将你的编辑器启动到正确的文件。这个工作坊中有很多文件,所以你会经常使用这个功能来在正确的时间到达正确的位置。

这应该能正常工作™️(它会查看你当前运行的进程并根据此选择编辑器)。如果它没有正确猜测,请在项目根目录创建一个.env文件,并添加一个名为EPICSHOP_EDITOR的环境变量,其值设置为你的编辑器可执行文件的路径。例如,如果你在Windows上使用VS Code,你应该在.env文件中添加以下内容:

EPICSHOP_EDITOR='"C:\Program Files\Microsoft VS Code\bin\code.cmd"'

确保如果路径包含空格,要用引号将路径括起来,如上所示(注意使用单引号包裹双引号!)。

EPICSHOP_EDITOR的值应该是你在终端中运行以从命令行打开编辑器的命令。这意味着,第一个应该是编辑器可执行文件的路径(或者如果你在PATH中有命令,则为该命令)。因此,你可能可以简单地这样做:

EPICSHOP_EDITOR=code

练习

  • exercises/*.*/README.md:练习背景信息
  • exercises/*.*/*.problem.*/README.*.md:问题说明
  • exercises/*.*/*.problem.*/*.tsx:带有表情符号辅助的练习 👈 你大部分时间都在这里。
  • exercises/*.*/*.solution.*/*.tsx:解决方案版本

练习的目的不是让你自己完成所有的材料。它的目的是让你的大脑思考在_我_讲解材料时要问我的正确问题。

有用的表情符号 🐨 🦺 💰 📝 🦉 📜 💣 💪 🏁 👨‍💼 🚨 🧝‍♀️

每个练习都有注释来帮助你完成练习。这些有趣的表情符号字符在这里帮助你。

  • 考拉Kody 🐨 会告诉你何时有具体的事情要做
  • 救生衣Lily 🦺 会帮助你处理练习中与TypeScript相关的部分
  • 钱袋Marty 💰 会在过程中给你具体的提示(有时还有代码)
  • 记事本Nancy 📝 会鼓励你记下你正在学习的内容
  • 猫头鹰Olivia 🦉 会给你有用的小知识/最佳实践注意事项
  • 文档Dominic 📜 会给你有用的文档链接
  • 炸弹Barry 💣 会在你需要炸毁(删除代码)的地方出现
  • 肌肉Matthew 💪 会表示你正在做练习
  • 方格旗Chuck 🏁 会表示你正在进行最后的工作
  • 产品经理Peter 👨‍💼 帮助我们了解用户想要什么
  • 警报Alfred 🚨 偶尔会在测试失败时出现,解释测试失败的可能原因
  • 同事Kellie 🧝‍♀️ 你的同事,有时会在你的练习之前完成工作

工作坊反馈

每个练习都有一个详细说明和反馈链接。请在练习和指导之后填写。

在工作坊结束时,请前往此URL提供总体反馈。 谢谢!https://kcd.im/rmx-workshop-ws-feedback

<!-- prettier-ignore-start --> <!-- prettier-ignore-end -->

编辑推荐精选

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

即梦AI

即梦AI

一站式AI创作平台

提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作

下拉加载更多