5分钟!前端最佳入门路径给你讲透

简介: 5分钟!前端最佳入门路径给你讲透

是新手如何快速掌握前端技能,成为一名合格的前端工程师。比如这个:

image.png


这位新手的困惑极具普遍性,多数人在面对前端纷繁复杂的技能树的时候,很容易随便找一个单点,陷进去拔不出来,然后产生无尽的挫败感。这便是典型的路径错误通常我们在面对巨型(复杂)事务的时候,很容易手忙脚乱,毫无头绪,不知道从哪里开始,也不知道到哪里算结束。人一旦进入这种状态,就势必会产生焦虑感,挫败感。更重要的是,事情本身会delay,实现周期被拉长。路径一旦错误,就可能越努力越挫败,且大概率容易半途而废我做前端十来年,虽然不是什么大牛,但也算总结了一些行之有效的方法论,可以给新入行的年轻人一些参考。话不多说,我们直接来看。

其实无论做什么事,不管是学一项新技能,还是在职场里攻坚一个新项目,或者交付一个复杂的新需求 ,对于未知领域知识的学习路径,都可以采用这样一个方法论来演进:image.png说到底,即便再厉害的人,直接面对和处理巨型事务时都会不知所措,所以我们必须对事务进行拆解,降低复杂度。通过这四步拆分,再大再难的事,都会变成小事,简单事,任何人都能轻易上手。

   小样(Demo)

01

小样的确立和选择很关键,介绍一个很有用的原则:

MVP(Minimum Viable Product)—— 最小可用产品

MVP原则其实通常是用在需求交付时候的,其核心有仨:

  1. 优先满足核心需求
  2. 成本尽可能最小
  3. 结果可及时验证

都很好理解对吧。第1点说的是,任何复杂事物,都可以根据第一性原理,抽取出核心路径(P0路径),想法设法把它跑完,就算能满足最核心诉求了。第2点说的是,在设计方案的时候需要考虑成本尽可能小,避免过度设计,超前设计第3点说的是,及时的结果验证,也就是持续交付。持续交付能有效减缓人的焦虑感,避免挫败感咦?不是在说学习新技能么,为什么听起来像在说一个需求的实现过程?是,也不是。其实对于前面这个case,我们可以把交付物看成是:一个能独立完成项目的前端工程师

你只需要找到实现这个交付物的核心路径,以最小的成本去实现,并且随时验证。

我们展开说说吧,看看怎么应用这个方法论。

要从新手,成长为一个合格的前端工程师,意味着你需要能独立完成一个项目。这是个复杂事务,我们对其进行拆解:


-> 找到一个项目(比如做个类似知乎的问答平台)
-> 找出核心路径(1. 问题列表,2. 问题详情,3. 提问,4. 回答)
-> 选个前端框架和UI库(比如React + AntDesign,降低启动成本)
-> 拼凑出核心路径涉及的4个模块。每拼凑出一个模块,用浏览器预览(及时验证),并奖励自己一顿好吃的(及时反馈)
   -> 拼出问题列表页
   -> 拼出问题详情页
   -> 拼出提问表单
   -> 拼出回答表单
-> Show Case,奖励自己一顿大餐,然后进入Step2。

经过这个MVP的迭代,你并没有深入学习三件套(HTML/CSS/JS),你甚至都没有了解清楚前端框架和UI库的细节,但你确实很快的实现了一个Demo。看着这个亲手搭建的Demo,你会无比的兴奋,不停的把玩。若如此,那么这一步的效果就达到了,我们进入下一步:重构

   重构(Refactoring)

02

这一部分,我们会把刚刚实现的Demo亲手毁掉,然后再以新的面貌涅槃重生:


-> 重构样式:
把UI库的样式去掉,想办法自己实现一模一样的样式。
(此时就要开始学CSS知识,可以参考着写,边写,边查,边学)。
-> 重构组件:
把UI库的组件逐步替换成自己实现的组件
(此时就要开始学Javascript和React)

以上两种重构中,每重构出一个组件或一个样式,就及时的验证和反馈。在这个过程中,你一点点的看着代码逐步被替换成自己的实现,但效果依然很棒,你会不断的产生自豪感,成就感。没错,这就是持续交付带来的快乐!完成所有代码的自研化之后,记得奖励自己一顿大餐,因为这意味着,你已经离最终目标不到一半的距离了。我们进入下一步:规范

   规范(normalization)

03

这一步之前,我们并没有花费多余的时间去纠结工程化的问题,而是采用刀耕火种的方式,用最原始的力量,完成了MVP的整体自研。

但一个成熟的项目,应该能够接纳其他开发人员的参与,协同开发才能使项目持续壮大。

而协同的前提,是项目必须足够规范,是具备一定工程化条件的。

工程化的知识点非常多,包括CICD,自动化测试,配置管理,容灾容错,监控,日志等等。对于一个新手,尤其是前端新手(非全栈),可以不用考虑那么多,只需要完成两小件事即可:

  • Build(构建)
  • Lint(校验)

通常来讲,你可以选择一个构建工具(比如webpack),将源码构建成浏览器可执行代码。对比源码和编译后代码,可以了解到诸多原理知识:构建编译原理,HTML原理,JS原理等等

另外,接入Lint(styleLint,esLint),对你的代码进行合规性校验。

完成这两件事,你的项目就具备最基本的工程化能力了,你也因此习得不少实用的技能,然后我们进入下一步:优化

   优化(optimization)

04

这一步之前,我们并没有关注代码的性能问题,我们只管实现了效果。

而你要知道,一个成熟的前端,和一个新手前端,即便实现了同样一个效果,其性能和代码优雅性也往往会天差地别。在这一步,我们就是要通过观察和解决一个个的性能问题,对前端知识体系进行查缺补漏,深入学习。
关于优化的方法论我就不展开了,之前也写过几篇文章可以供参考:《前端性能优化思想模型,在自动驾驶领域的实践》—— 这篇高度抽象了性能优化的思想模型,学到就是赚到。
代码优雅性反映出你的思维高度》—— 这篇主要介绍了一些实用的优雅代码的写法,一定程度可以提升新手的思维高度。当然了,网上有很多的优化方法,但其实优化本身就是一个见招拆招的事,这一步需要不断的积累实战经验,不是背八股文就能习得的。


好了,经过上述4个Step,前端(浏览器端)的东西基本上就学的差不多了,如果你每一步都有所交付,那你基本算是入门了。

你有没有发现,你并没有顺着大纲去学一些枯燥的,不知道什么时候什么场景能用上的知识,而是在真实的实践中,不知不觉的,一点点把前端知识逐步啃下来了。每一个步骤的每一个环节,你都能及时的看到效果,及时的给自己成就感,这样便能不断的推进着自己进入下个环节。蓦然回首,你惊喜的发现,曾经懒散的自己居然也产生了伟大的自驱力。


目录
相关文章
|
3月前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
693 2
|
4月前
|
前端开发
【前端web入门第四天】02 CSS三大特性+背景图
本文详细介绍了CSS的三大特性:继承性、层叠性和优先级,并深入讲解了背景图的相关属性,包括背景属性、背景图的平铺方式、位置设定、缩放、固定以及复合属性。其中,继承性指子元素自动继承父元素的文字控制属性;层叠性指相同属性后定义覆盖前定义,不同属性可叠加;优先级涉及选择器权重,包括行内样式、ID选择器等。背景图部分则通过具体示例展示了如何设置背景图像的位置、大小及固定方式等。
270 91
|
2月前
|
编解码 前端开发 JavaScript
从入门到精通:揭秘前端开发中那些不为人知的优化秘籍!
前端开发是充满无限可能的领域,从初学者到资深专家,每个人都追求更快、更稳定、更用户体验友好的网页。本文介绍了四大优化秘籍:1. HTML的精简与语义化;2. CSS的优雅与高效;3. JavaScript的精简与异步加载;4. 图片与资源的优化。通过这些方法,可以显著提升网页性能和用户体验。
25 3
|
2月前
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
187 1
|
4月前
|
JavaScript 前端开发 小程序
一小时入门Vue.js前端开发
本文是作者关于Vue.js前端开发的快速入门教程,包括结果展示、参考链接、注意事项以及常见问题的解决方法。文章提供了Vue.js的基础使用介绍,如何安装和使用cnpm,以及如何解决命令行中遇到的一些常见问题。
114 5
一小时入门Vue.js前端开发
|
3月前
|
自然语言处理 资源调度 前端开发
前端大模型入门(四):不同文本分割器对比和效果展示-教你如何根据场景选择合适的长文本分割方式
本文详细介绍了五种Langchain文本分割器:`CharacterTextSplitter`、`RecursiveCharacterTextSplitter`、`TokenTextSplitter`、`MarkdownTextSplitter` 和 `LatexTextSplitter`,从原理、优缺点及适用场景等方面进行了对比分析,旨在帮助开发者选择最适合当前需求的文本分割工具,提高大模型应用的处理效率和效果。
273 1
|
3月前
|
机器学习/深度学习 人工智能 自然语言处理
前端大模型入门(三):编码(Tokenizer)和嵌入(Embedding)解析 - llm的输入
本文介绍了大规模语言模型(LLM)中的两个核心概念:Tokenizer和Embedding。Tokenizer将文本转换为模型可处理的数字ID,而Embedding则将这些ID转化为能捕捉语义关系的稠密向量。文章通过具体示例和代码展示了两者的实现方法,帮助读者理解其基本原理和应用场景。
657 1
|
3月前
|
人工智能 前端开发 JavaScript
前端大模型入门(二):掌握langchain的核心Runnable接口
Langchain.js 是 Langchain 框架的 JavaScript 版本,专为前端和后端 JavaScript 环境设计。最新 v0.3 版本引入了强大的 Runnable 接口,支持灵活的执行方式和异步操作,方便与不同模型和逻辑集成。本文将详细介绍 Runnable 接口,并通过实现自定义 Runnable 来帮助前端人员快速上手。
|
3月前
|
存储 JavaScript 前端开发
前端开发:Vue.js入门与实战
【10月更文挑战第9天】前端开发:Vue.js入门与实战
|
3月前
|
前端开发 JavaScript 开发者
探索现代Web前端技术:React框架入门
【10月更文挑战第9天】 探索现代Web前端技术:React框架入门