DEV 的年度热文, 读完觉得不错, 所以翻译出来供大家参考, 个人水平有限, 文中可能会有一些翻译错误, 可以在评论区指正.
本篇文章一共涉及了 9 个流行的框架 / 库, 没有具体的介绍使用方法, 而是给了一些非常棒的实战教程.
初学者 (也许一些有经验的开发者也是一样) 在读完官方文档, 想写一个项目练手的时候不知道做什么项目好, 或是有想法, 但是无从下手. 那么这篇文章将会给你带来很大的帮助.
导读
无论你是编程新手还是经验丰富的开发人员. 在这个行业中, 我们不得不一直学习新概念和新语言或是框架, 才能跟上快速变化. 以 React 为例 -- Facebook 四年前开源, 现在它已经成为了全球 JS 开发者的首选. 但是与此同时, vue 和 Angular 也有自己的追求者. 然后是 Svelte,Next 和 Nuxt.JS,Gatsby,Gridsome,quasar 等等, 如果你想成为专业的 JavaScript 开发人员, 你在使用自己熟悉的框架进行开发的同时, 还需要对不同的框架和库有一些了解.
为了帮助你在 2020 年成为一个前端大神, 我收集了 9 个使用了不同 JS 框架 / 库的项目, 你可以去构建或者将他们加入到自己未来的开发计划中. 记住, 没什么比实际开发一个项目更有帮助. 所以, 不要犹豫, 试着去开发一下.
1. 使用 React(with hooks)构建一个电影搜索应用
首先, 你可以使用 React 构建一个电影搜索应用. 展示如下:
你将学到什么?
构建这个项目, 你可以使用较新的 Hook API 来提升你的 React 技能. 示例项目使用了 React 组件, 很多 hooks 以及一些外部的 API, 当然还有一些 CSS 样式.
技术栈 / 点
- React(Hooks)
- create-react-App
- JSX
- CSS
你可以在这里看到这个示例项目: www.freecodecamp.org/news/how-to...
2. 使用 Vue 构建一个聊天应用
另外一个要介绍给你的很棒的项目是使用 Vue 构建的聊天应用程序. 展示如下:
你将学到什么?
您将学习到如何从头开始设置 Vue 应用, 创建组件, 处理状态, 创建路由, 连接到第三方服务, 甚至是处理身份验证.
技术栈 / 点
- Vue
- Vuex
- Vue Router
- Vue CLI
- Pusher
- CSS
这真的是一个非常棒的项目, 不管是用来学习 Vue 或者是提升现有的技能, 以应对 2020 年的发展. 你可以查看这个教程: www.sitepoint.com/pusher-vue-...
3. 使用 Augular8 构建一款漂亮的天气应用
此示例将帮助你使用 Google 的 Angular 8 来构建一块漂亮的天气应用程序:
你将学到什么?
该项目将教你一些宝贵的技能, 例如从头开始创建应用, 从设计到开发, 一直到生产就绪部署.
技术栈 / 点
- Angular 8
- Firebase
- SSR
网络布局和 Flexbox
移动端友好 && 响应式布局
深色模式
漂亮的用户界面
对于这个综合项目, 我真正喜欢的是, 不是孤立地学习东西, 而是从设计到最终部署的整个开发过程.
medium.com/@hamedbaato...
4. 使用 Svelte 构建一个 To-Do 应用
与 React,Vue 和 Angular 相比, Svelte 还很新, 但仍是热门之一. 好的, To-Do 应用不一定是那里最热门的项目, 但这确实可以帮助你提高 Svelte 技能, 如下:
你将学到什么?
本教程将向你展示如何从头到尾使用 Svelte3 制作应用. 它利用了组件, 样式和事件处理程序.
技术栈 / 点
- Svelte 3
- Components
- CSS
ES6 语法
Svelte 没有太多优秀的入门项目, 这个是我觉得不错的一个上手项目: medium.com/codingthesm...
5. 使用 Next.JS 构建购物车
Next.JS 是一个轻量级的 React 服务端渲染应用框架, 该项目将向你展示如何构建一个如下所示的购物车:
你将学到什么?
在这个项目中, 你将学习如何设置 Next.JS 的开发环境, 创建新页面和组件, 获取数据, 设置样式并部署一个 next 应用.
技术栈 / 点
Next.JS
组件和页面
数据获取
样式
部署
SSR 和 SPA
你可以在此处找到该教程: snipcart.com/blog/next-j...
6. 使用 Nuxt.JS 构建一个多语言博客网站
Nuxt.JS 是 Vue 服务端渲染应用框架. 你可以创建一个如下所示的应用程序:
你将学到什么?
这个示例项目从初始设置到最终部署一步一步教你如何使用 Nuxt.JS 构建一个完整的网站. 它使用了 Nuxt 提供的许多出色功能, 如页面和组件以及 SCSS 样式.
技术栈 / 点
Nuxt.JS
组件和页面
Storyblok 模块
- Mixins
- Vuex
- SCSS
Nuxt 中间件
这个项目包含了涵盖了 Nuxt.JS 的许多出色功能. 我个人很喜欢使用 Nuxt 进行开发, 你应该尝试使用它, 这将使你成为更好的 Vue 开发人员! www.storyblok.com/tp/nuxt-JS-...
除此之外, 我还找到了一个 B 站的视频: www.bilibili.com/video/av211...
7. 使用 Gatsby 构建一个博客
Gatsby 是一个出色的静态站点生成器, 它允许使用 React 作为渲染引擎引擎来搭建一个静态站点, 它真正具有现代 web 应用程序所期望的所有优点. 该项目如下:
你将学到什么?
在本教程中, 你将学习如何利用 Gatsby 构建出色的博客.
技术栈 / 点
- Gatsby
- React
- GraphQL
- Plugins & Themes
- MDX / Markdown
- Bootstrap CSS
- Templates
如果你想创建博客, 这个示例教你如何利用 React 和 GraphQL 来搭建. 并不是说 WordPress 是一个不好的选择, 但是有了 Gatsby , 你可以在使用 React 的同时创建高性能站点!
blog.bitsrc.io/how-to-buil...
8. 使用 Gridsome 构建一个博客
Gridsome 和 Vue 的关系与 Gatsby 和 React 的关系一样. Gridsome 和 Gatsby 都使用 GraphQL 作为数据层, 但是 Gridsome 使用的是 vuejs. 这也是一个很棒的静态站点生成器, 它将帮助您创建出色的博客:
你将学到什么?
该项目将教你如何使用 Gridsome,GraphQL 和 Markdown 构建一个简单的博客, 它还介绍了如何通过 Netlify 部署应用程序.
技术栈 / 点
- Gridsome
- Vue
- GraphQL
- Markdown
- Netlify
当然, 这不是最全面的教程, 但涵盖了 Gridsome 和 Markdown 的基本概念, 可能是一个很好的起点.
www.telerik.com/blogs/build...
9. 使用 Quasar 构建一个类似 SoundCloud 的音频播放器
Quasar 是另一个 Vue 框架, 也可以用于构建移动应用程序. 在这个项目中, 你将创建一个音频播放器应用程序, 如下所示:
你将学到什么?
不少项目主要关注 Web 应用程序, 但这个项目展示了如何通过 Quasar 框架创建移动应用程序. 你应该已经配置了可工作的 Cordova 设置, 并配置了 Android studio / xcode. 如果没有, 在教程中有一个指向 quasar 网站的链接, 在那里你可以学习如何进行设置.
技术栈 / 点
- Quasar
- Vue
- Cordova
- Wavesurfer
- UI Components
一个展示了 Quasar 在构建移动应用程序方面的强大功能的小项目: www.learningsomethingnew.com/how-to-buil...
总结
本文展示了你可以构建的 9 个项目, 每个项目专注于一个 JavaScript 框架或库. 现在, 你可以自行决定: 使用以前未使用的框架来尝试一些新的东西或是通过做一个项目来提升已有的技能, 或者在 2020 年完成所有项目?
来源: http://www.tuicool.com/articles/uIVFJbI