2019年,全栈开发者应该学些什么?

对于什么是全栈开发者并没有一个明确的定义。但是,有一件事是肯定的:2019年对全栈开发者的需求量很大。在本文中,我将向你概述一些趋势,你可以尝试根据这些趋势来投入你的时间。

简单地说,全栈开发者就是可以构建完整应用程序的人。他们了解前端和后端技术、工具和服务,并结合所有这些技能开发出可以在生产环境中运行的东西。

这是美国全栈开发者在2019年的工资走势:

\

人生苦短,所以尽量少做无用功。如果你希望保持最新状态并成为全栈开发者,你需要了解以下的2019年趋势。

前端

基础

HTML、CSS和JavaScript是必须掌握的,你还需要学习React、Vue或Angular等前端框架或库。但是,你应该选择哪一个?对于一个真正的全栈开发者,你可以在2019年选择这三个框架中的任何一个。

来自React 16的更新

你需要了解React的基础知识及其基于单向数据流架构的组件。今年我们看到了React 16的大量更新和2019年即将发布的一些小版本更新。

新的生命周期方法;

  • React 16.6中的Suspense for Code Splitting(已发布);

  • 带有React Hooks的16.x版本(2019年第一季度);

  • 带有并发模式的16.x版本(2019年第二季度);

  • 带有Suspense for Data Fetching的16.x版本(2019年中)。

这意味着你需要知道如何使用React.lazy()和\u0026lt; React.Suspense\u0026gt;进行代码拆分,使用React.memo进行优化,并时刻关注新功能,如React Hooks,它可能会给React生态系统带来重大改变。

我们现在还有标准化的React Context API,你应该对它有一个基本的了解。

React生态系统将在2019年继续发展和演化。它这不仅限于Web,在移动、物联网和AR/VR等不同平台上移植和使用React的能力将使其变得越来越重要,并在2019年领先于其他2个库。

Vue 3.0

2018年,Vue持续获得开发者的青睐,2019年将会继续增长……但它是否足以超越其他两大玩家?我们拭目以待。

Vue生态系统正在不断发展,而且,随着Vue 3.0的发布极其改进的Vue CLI,2019年的开发者体验将比以往更好。

开发者可以使用Vue Native进行跨平台开发(就像React Native那样),我们已经很接近React那样的大型生态系统,但还是有一大段距离。

Vue有一个非常有趣的趋势,它将在2019年继续增长:阿里巴巴、百度、腾讯、小米和DJI等中国科技巨头更喜欢Vue。预计中国市场将继续保持快速增长,因为Vue是一个独立的开源库,与西方的大型科技巨头无关。

Angular Ivy和Angular Elements

新的渲染引擎Ivy即将推出,性能将会得到大幅提升。

Ivy将成为Angular渲染引擎的第三个化身,它的目标是成为更小、更快、更简单的编译器。

Angular Elements将使我们能够在Angular以外的其他环境中使用Angular组件。简单地说就是你可以构建可以被添加到不使用Angular的HTML页面中的组件,有点像Web组件。现在,我可以使用Angular创建世界上最好的组件,并将它交给我的朋友,她将它用在她的React应用程序中!

2019年,Angular将继续做他们擅长的事情:提供一个功能齐全的框架,用于构建丰富的Web应用程序。

Angular、Vue、React——更小更快

总的来说,2019年将看到这3个前端库的发展。如前所述,你只要掌握其中一个,就已经为进入新的一年做好了准备。预计在2019年,这些库都会发生微小的变化,提高渲染速度并缩小库的体积……但它们都不会带来任何重大改进来压倒其他库。

CLI将会风靡

你必须使用babel、webpack、eslint、测试库和其他工具搭建项目脚手架的日子已经一去不复返了。我的意思是,我们仍然可以这么做,但CLI确实让这种体验变得更好了。

  • Angular CLI;

  • Create React App 2;

  • Vue CLI。

2019年,我们将在CLI中看到越来越多的改进体验。

状态管理
  • Vue将继续使用Vuex进行状态管理。

  • Angular将继续主要使用RxJS。

  • 随着新的Context API的问世和GraphQL + Apollo的普及,React今年则遭遇了一点危机。很长一段时间以来,Redux第一次被认为不是状态管理的明智选择。你仍然需要学习Redux,因为你可以从Redux中学到一些有用的计算机科学原理,如事件溯源和CQRS。

新的Context API、Redux和GraphQL

Apollo内置的离线客户端缓存将使Apollo + GraphQL在2019年成为Redux的一个重要替代品(当然,从技术上讲,可以同时使用它们)。新的Context API问世了,很多人称它为Redux终结者。

2019年,你需要了解它们三者,了解它们的工作原理,以及它们可以用来解决哪些问题。但如果从就业方面来看,学习Redux仍然是一个很好的选择。

服务器端渲染

服务器端渲染在JavaScript领域仍然是一个待解决的问题。我们知道,单页应用程序和客户端渲染很容易让项目出现代码膨胀,而且需要向客户端发送太多的JavaScript代码,而且可能会影响你的SEO(但可能没有你想象的那么多)。

有一些方法可以解决这个问题,例如:PRPL模式、prerender.io,或者你可以这么想,其实谷歌机器人在抓取单页应用程序时没有那么糟糕。

目前,如果要进行服务器端渲染,可以使用:

  • 用于React的Next.js;

  • 用于Vue的Nuxt.js;

  • 用于Angular的Angular Universal。

静态页面正在重新刮起一阵流行风,你可以看看JAM Stack。

它的主要思想是:预构建标记(静态页面),通过利用服务器的API在客户端成为动态单页面应用程序。这将在2019年真正改变服务器端渲染,我预测会有更多人使用像GatsbyJS这样的工具,而不是自己构建复杂的服务器端渲染逻辑。

Web组件

浏览器采用的Web组件终于离我们想要的标准越来越近了。2019年,我们将看到更多关于Web组件的讨论,但它仍然不会在2019年达到临界点。你可以密切地关注它们,但不需要花费大量时间在掌握如何构建Web组件上。

你可以了解React、Angular、Vue和普通HTML的组件,但很难说Web组件会在什么时候得到大规模采用并为我们带来主要的好处。

性能

每个人都喜欢谈论性能。2019年,代码拆分可能会成为标准实践,更多新的优化图像格式(如WebP)将会发挥越来越重要的作用。

人们仍然会讨厌谷歌的AMP。

你应该学习并为2019年做好准备的是:

  • 针对Angular、React、Vue的特定优化;

  • 代码拆分;

  • Tree Shanking;

  • 只传输必要的JavaScript代码;

  • 更加关注你正在使用的NPM库,并最大限度地减少库的大小;

  • 制定性能预算;

  • 通过使用CDN和浏览器优先级工具更好地确定资源优先级。

PWA

渐进式Web应用程序在2019年仍然会很热门,但它最复杂的功能可能不会流行起来(即推送通知)。

大多数情况下,你将使用HTTPS、App Shell和Service Worker来获得一些额外的脱机功能、安全性和性能。你应该学习如何构建PWA,并使用像Lighthouse这样的工具来测试它。

Safari最终为PWA添加了一些支持,实现渐进式Web应用程序功能可能会更容易一些。但说到底,你需要先学会使用manifest.json文件和Service Worker。谷歌正在这方面努力推进,但不要指望在2019年会看到任何突破。

后端

别担心!2019年的后端世界并不会像前端世界那样疯狂。

HTTPS无处不在

需要将用户输入的数据发送到服务器的网站必须使用HTTPS。如果你没有使用HTTPS,谷歌将会惩罚你。幸运的是,HTTPS Everywhere或Gaddy让迁移到HTTPS变得更容易。

REST与GraphQL

RESTful API在2019年还会存在,你需要学习如何实现和设计这些API。你应该学会使用Node.js和Express.js来创建API服务器,在2019年,这两个框架的组合仍然会占主导地位。

现在出现了很多有关GraphQL的炒作,但它还不是可以赢得所有市场的大赢家。了解GraphQL可以解决哪些问题,以及如何在RESTful API中用它来进行路由优化。这将是2019年最重要的趋势:不是如何单独使用GraphQL,而是如何在极少数情况下使用GraphQL优化一些RESTful API路由。

HTTP2

HTTP2变得越来越普遍,你需要知道如何使用这个协议来优化内容的传输。此外,HTTP3正在开发当中,你可以关注它,但它并不是你在2019年需要过分关注的东西。

基础设施即服务

需要自己构建和管理服务器的场景越来越少,以下是2019年的主要选择。

  • Digital Ocean——用于简单的服务器。

  • Heroku——用于简单和集成的服务器和部署。

  • Now——用于超级简单的部署。

  • Firebase——用于托管基础设施和数据库。

  • AWS——几乎任何你想要的东西,你可以永远不需要考虑自己管理服务器。

你需要学习SQL

\

Firebase、AWS等托管数据库将继续增长,但你还是需要学习SQL。2019年,像PostgreSQL这样的数据库将继续发展,而像MongoDB这样的NoSQL数据库似乎会有所下降。你可能需要了解每种方案的优点和缺点,因为在数据库领域并没有可以解决所有问题的完美解决方案。

不要把搜索给忘了

搜索可能不是绝对必要的,但它是Web的重要组成部分。2019年,全栈开发者可以试着了解下面两个平台:

  • Elasticsearch;

  • Algolia Search;

你可能需要学习Redis

了解使用Redis作为缓存以及内存存储的工作原理。缓存和内存存储是2019年需要学习的重要概念,可以用它们来优化你的系统。Redis是理解这些概念的一个很好的起点。

测试

学习三种测试类型

很多人都在讨论这个话题,但为了简单问题,可以将测试分解为三种类型:

  • 单元测试:给定输入,测试输出,用于测试单个函数或类。

  • 集成测试:测试流程或组件是否按预期运行(包括副作用)。

  • 端到端测试:测试用户的实际行为,不仅仅是测试一个简单的功能。

保持简单

测试框架有很多选择,但下面是2019年最好的两个组合:

  • Jest(https://jestjs.io/)

  • Mocha + Chai + Sinon + Istanbul

将Jest视为一体化的测试框架,就不需要像第二个选项那样添加其他工具和库。如果你想要简单些,只需使用Jest。如果你想要更多可定制性和模块化,请选择Mocha。

如果你还了解这些,那是锦上添花:Mock、Spy、存根和快照测试。

适当的端到端测试就可以了

进行端到端测试需要公司投入大量的成本,所以在你的职业生涯中有可能会也有可能不会遇到这种测试。但不管怎样,在2019年,你最好可以学习这些框架,或至少可以了解一下:

  • Cypress;

  • Nightwatch;

  • Protractor,适合Angular爱好者。

移动开发

跟移动开发说再见?

\

移动开发在2019年的日子可能会有点难过。应用程序的下载量不像过去那么多,而且最热门的下载要么是游戏,要么是大型科技公司的应用程序。2019年,移动端Web浏览量将超过原生移动应用程序。因此,对于全栈开发者和移动开发者而言,他们应该将更多的关注点放在移动设备Web应用程序上(例如使用PWA)。

iOS和Android仍然是企业所需要的重要开发技能,但在过去几年中对它们的需求一直在下降,似乎出现了从原生移动开发到React Native引领的混合开发(或接近原生)的重大转变。如果你看一下上面的图表,React Native已经取代了Swift,它是原生iOS开发的主要编程语言。

以下是你需要关注的开发技术:

React Native在2018年遭遇了一些挫折,一些大公司在博文说他们正在放弃它。但这些公司都曾经尝试将React Native添加到他们现有的iOS或Android代码库中。如果你是这方面的新手,对于你来说,它仍然是2019年的一个很好的选择。它将会继续增长下去。

Flutter在2018年非常火爆,但现在判断它在2019年将会怎样发展还为时过早。你需要关注它,但到目前为止,它并没有带来比React Native更显著的优势。

Ionic和NativeScript的使用将在2019年逐渐减少,除非你正在使用Angular,否则你不应该关注它们。

所以,在2019年,请继续关注React Native。

工具

你应该使用的NPM包

  • Prettier——让你可以专注于你正在写的代码,而不是去关心代码的格式;

  • eslint——保持代码整洁;

  • date-fns——moment.js的轻量级替代品;

  • lodash——主要用于throttle()和debounce()函数;

  • rambda——如果你真的喜欢函数式编程。

JavaScript

JavaScript是饱受争议的编程语言之一。2018年,静态类型在JavaScript的动态类型领域变得越来越受欢迎。那么竞争者有哪些?

  • TypeScript:可以编译为JavaScript的JavaScript超集。

  • Flow:JavaScript的静态类型检查器。

  • Reason:利用了JavaScript和OCaml生态系统的类型语言。

  • PureScript:一种强类型语言,可以编译为JavaScript,使用Haskell开发。

  • Elm:纯粹的函数式编程语言,可以编译成JavaScript。

关于静态与动态类型语言的讨论由来已久,不会很快就得出结论。以上这些都不会取代JavaScript作为Web主要编程语言的主导地位。但是,Angular和Vue都采用了TypeScript,并将其作为开发者社区的标准,因此,TypeScript可能会继续增长,并超越上述其他语言。

你需要学习TypeScript的基础知识及其原理(以及静态类型的好处),但要注意,它并非写出好代码的唯一方法。要写出好代码,可以先关注如何写出好的单元测试。

模块捆绑器

Webpack 4和Parcel是2019年的主要工具。它们都朝着降低复杂性和更多“为用户着想”的方向发展,很多前端库都提供了CLI。学习这两个工具,但请记住,CLI在项目开始时帮你消除掉最初80%的复杂性。如果要发布NPM包,请使用Rollup。

计算机科学基础

数据结构+算法

讨论技术趋势的文章很少会提到计算机科学基础知识。但这可能是最重要的主题,而且我可以非常自信地说,这个趋势具有99.99999%的准确率:如果你想在2019年和未来几年成为一个全栈开发者,计算机科学基础是非常重要的。计算机科学基本原理不怎么会发生变化,并且已经存在了很长时间,不会像开发库那样,一旦有新东西出来就变得过时了。

容器和serverless

容器为我们提供了与几年前完全不同的架构,其中的一个主要的想法是serverless。serverless并不是说不需要服务器了,而是说有人为你管理服务器(基础设施),你可以专注于自己的应用程序逻辑,无需担心扩展性等问题。

serverless的流行始于2017年,并持续到了2018年。2019年,我们将看到一些相同的常见用例,比如AWS API Gateway与AWS Lambda的结合,供前端应用程序代码调用。

在降低成本的同时提高性能是一个好主意,如果冷启动问题在2019年可以得到解决,那么它将变得越来越流行。

平台即服务/后端即服务

亚马逊、谷歌和Azure将在2019年争夺服务器市场,它们当中的每一个都提供了全托管的服务。

AppSync、Amplify、App Services、App Engine等服务将继续发展,但由于程序员很难放弃如此多的控制权(除非是小型的个人项目),所以它们并不会真正有大起色。

2019年,Azure将主导企业市场,AWS将主导一般的开发者市场,而谷歌将主导机器学习市场。

机器学习

2019年,你需要学习并了解如何通过以下API使用机器学习模型:

  • Google Cloud AI;

  • 亚马逊机器学习;

  • Azure机器学习;

除了之前列出的平台即服务和后端即服务,还会有更多的服务出现,这些大公司提供的机器学习API和模型将在2019年成为一个更重要的趋势。你应该学会在未来的项目中使用其中一些(不用担心,它们使用起来没有那么难,就像使用大多数其他API一样)。

2019年,我们将可以看到机器学习API在Web上的应用,而不是从头开始构建自己的机器学习模型。因为与上述大型科技巨头不同,大多数人或公司无法为机器学习提供足够的资源或数据。

WebAssembly

WebAssembly集将继续缓慢改进,但仍然只有一小部分开发者会使用它(主要用于游戏、图像处理)。你可以先了解它,在几年后等它成为主流时你就是这方面的专家了。

以上是我的个人意见,不管怎样,学习新东西绝不是一个坏主意。

英文原文:
https://medium.com/zerotomastery/top-libraries-tech-to-learn-in-2019-for-full-stack-developers-f8c0331b8a00

更多内容,请关注前端之巅(ID:frontshow)

\

你可能感兴趣的:(2019年,全栈开发者应该学些什么?)