本次预计翻译三篇文章如下:
- 01.[译]9 个可以让你在 2020 年成为前端专家的项目
- 02.[译]预加载响应图像
- 03.[译]您应该知道的 13 个有用的 JavaScript 数组技巧
我为什么要创建这个 git 仓库?通过翻译国外的 web 相关的技术文章来学习和跟进 web 发展的新思想和新技术。git 仓库地址:https://github.com/yzsunlei/javascript-article-translate
介绍
无论您是编程新手还是经验丰富的开发人员。在互联网这个行业中,必须不断学习新的概念和语言 / 框架以跟上快速变化的步伐。以 React 为例 – 4 年前由 Facebook 开源,它现在已经成为全球 JavaScript 开发人员的首选。Vue 和 Angular 当然也有其相应的追捧者。然后是 Svelte,以及 Next.js 或 Nuxt.js 等通用框架,以及 Gatsby,Gridsome,Quasar 等等。如果您想成为一名专业的 JavaScript 开发人员,那么您至少应该在不同的框架和库中拥有一些实战经验 – 除了使用原生的 JS 完成工作任务。
为了帮助您在 2020 年成为前端专家 (Frontend Master),我收集了 9 个不同的项目,每个项目都有不同的主题和不同的 JavaScript 框架或库作为技术栈,您可以构建这些项目并将其添加到学习目标中。请记住,没有什么比项目实战(actually building stuff) 对您有更大的帮助了,因此,请不断进取(sharpen your mind),实现这一目标!
使用 React(使用钩子)构建电影搜索应用程序
首先,您可以使用 React 构建电影搜索应用程序。下面是应用程序最终的示例图:
您将学到什么
构建这个应用程序,您将使用相对较新的 Hooks API 来提升您的 React 技能。示例项目利用了 React 组件,钩子,一个外部 api,当然还有一些 CSS 样式。
技术栈和功能
- React with Hooks
- create-react-app
- JSX
- CSS
不使用任何类,该项目为您提供了功能的完美切入点,并且肯定会在 2020 年为您提供帮助。您可以在此处找到示例项目:https://www.freecodecamp.org/news/how-to-build-a-movie-search-app-using-react-hooks-24eb72ddfaf7/ 请按照本教程进行操作,或者按照您自己的方式进行!
使用 Vue 构建聊天应用
对您来说,另一个很棒的项目是使用我最喜欢的 JavaScript 库 VueJS 构建聊天应用程序。该应用程序将如下所示:
您将学到什么
在本教程之后,您将学习如何从头开始配置 Vue 应用,创建组件,处理状态,创建路由,连接到第三方服务,甚至处理身份验证。
技术栈和功能
- Vue
- Vuex
- Vue Router
- Vue CLI
- Pusher
- CSS
这真的是一个很棒的项目,可以开始使用 Vue 或提升您现有的技能以应对 2020 年的开发。您可以在此处找到该教程:https://www.sitepoint.com/pusher-vue-real-time-chat-app/
使用 Angular 8 构建美丽的天气应用
此示例将帮助您使用 Google 的 Angular 8 构建美观的天气应用程序:
您将学到什么
该项目将教您一些宝贵的技能,例如从头开始创建应用程序,从设计到开发,一直到生产部署。
技术栈和功能
- Angular 8
- Firebase
- 服务端渲染
- 使用栅格布局和 Flex 布局
- 移动端友好 & 响应式
- 暗黑模式
- 漂亮的 UI
对于这个综合性项目,我真正喜欢的是,您不是单一地学习东西,而是从设计到最终部署的整个开发过程。您应该真正做到这一点!https://medium.com/@hamedbaatour/build-a-real-world-beautiful-web-app-with-angular-6-a-to-z-ultimate-guide-2018-part-i-e121dd1d55e
使用 Svelte 构建待办应用
与 React,Vue 和 Angular 相比,Svelte kinda 是新手,但仍是 2020 年的热门话题之一。好的,To-Do 应用程序不一定是那里最热门的话题,但这确实可以帮助您提高 Svelte 技能看起来像这样:
您将学到什么
本教程将向您展示如何从头到尾使用 Svelte 3 制作应用。它应用了组件,样式和事件处理程序。
技术栈和功能
- Svelte 3
- 组件
- 通过 CSS 样式
- ES 6 语法
那里没有很多优秀的 Svelte 入门项目,因此我觉得这是一个很好的起点。谁知道呢,也许您是在创建另一篇更全面的 Svelte 教程的人,它将在本帖子的明年版本中介绍?https://medium.com/codingthesmartway-com-blog/building-a-svelte-3-todo-app-from-start-to-deployment-1737f72c23a6
使用 Next.js 构建电子商务购物车
NextJs 是用于创建支持应用程序开箱即用的 React 应用程序的最受欢迎的框架。该项目将向您展示如何构建一个如下所示的电子商务购物车:
您将学到什么
在这个项目中,您将学习如何设置 Next.js 开发环境,创建新页面和组件,获取数据,样式并部署下一个应用程序。
技术栈和功能
- Next.js
- 组件和页面
- 数据获取
- 样式
- 部署方式
- SSR 和 SPA
拥有一个真实的例子(例如电子商务展示柜)来学习新的东西总是很高兴。您可以在这里找到该教程:https://snipcart.com/blog/next-js-ecommerce-tutorial
建立完整的多语言博客网站 Nuxt.js
Nuxt.js 对 Vue 的作用是 Next.js 的反映。一个很好的框架,可以结合服务器端渲染和单页应用程序的功能。您可以创建的最终应用程序将如下所示:
您将学到什么
这个示例项目将教您从初始设置到最终部署,如何使用 Nuxt.js 构建完整的网站。它利用了 Nuxt 必须提供的许多优秀功能,如页面和组件以及 SCSS 样式。
技术栈和功能
- Nuxt.js
- 组件和页面
- Storyblok 模块
- 混合(Mixins)
- Vuex 状态管理
- SCSS 样式
- Nuxt 中间件
这对您来说是一个非常酷的项目,涵盖了 Nuxt.js 的许多优秀功能。我个人很喜欢使用 Nuxt,因此您应该真正尝试使用它,因为它也将使您成为更好的 Vue 开发人员!https://www.storyblok.com/tp/nuxt-js-multilanguage-website-tutorial
用 Gatsby 建立博客
Gatsby 是一个出色的静态站点生成器,在后台使用 React 和 GraphQL。这是该项目的结果:
您将学到什么
在本教程中,您将学习如何利用 Gatsby 构建优秀的博客,在使用 React 和 GraphQL 的同时可以很好地编写自己的文章。
技术栈和功能
- Gatsby
- React
- GraphQL
- 插件和主题
- MDX/Markdown
- Bootstrap
- 模板
如果您想创建博客,这是一个很好的示例,说明如何利用 React 和 GraphQL 做到这一点。我并不是说 Wordpress 是一个不好的选择,但是有了 Gatsby,您可以在使用 React 的同时创建高性能站点!https://blog.bitsrc.io/how-to-build-a-blog-with-gatsby-and-boostrap-d1270212b3dc
用 Gridsome 建立博客
Gridsome 适用于 Vue,好吧,我们已经在 Next/Nuxt 中拥有了,但是 Gridsome 和 Gatsby 也是如此。两者都使用 GraphQL 作为数据层,但是 Gridsome 使用 VueJS。这也是一个很棒的静态站点生成器,它将帮助您创建出色的博客:
您将学到什么
该项目将教您如何构建一个简单的博客,以开始使用 Gridsome,GraphQL 和 Markdown。它还介绍了如何通过 Netlify 部署应用程序。
技术栈和功能
- Gridsome
- Vue
- GraphQL
- Markdown
- Netlify
当然,这不是最全面的教程,但涵盖了 Gridsome 和 Markdown 的基本概念,可能是一个很好的起点。
https://www.telerik.com/blogs/building-a-blog-with-vue-and-markdown-using-gridsome
使用 Quasar 构建类似于 SoundCloud 的音频播放器应用
Quasar 是另一个 Vue 框架,也可以用于构建移动应用程序。在这个项目中,您将创建一个音频播放器应用程序,如下所示:
您将学到什么
尽管其他项目主要关注 Web 应用程序,但该项目将向您展示如何通过 Quasar 框架使用 Vue 创建移动应用程序。您应该已经配置了 Cordova 工作环境,并配置了 android studio/xcode。如果没有,则在教程中有一个指向 quasar 网站的链接,他们向您介绍了如何进行设置。
技术栈和功能
- Quasar
- Vue
- Cordova
- Wavesurfer
- UI 组件
一个小项目,展示了 Quasar 在构建移动应用程序方面的强大功能。https://www.learningsomethingnew.com/how-to-build-a-sound-cloud-like-audio-player-app-with-vue-js-quasar-and-wave-surfer
结论
在本文中,我向您展示了您可以构建的 9 个项目,每个项目专注于一个 JavaScript 框架或库。现在,选择权全由您自己决定:您是否会使用以前未使用的框架来尝试一些新的东西?还是要通过为已经具备一定知识的技术进行项目来增强技能?还是您会依赖自己喜欢的框架 / 库,并在 2020 年完成所有项目?随时发表评论,不要忘记关注我,以获取更多即将发布的帖子!
原文链接:https://dev.to/simonholdorf/9-projects-you-can-do-to-become-a-frontend-master-in-2020-n2h