如何学习一个框架

简介: 那么我们如何正确的学习一个框架,什么时候该看源码,学到什么程度再看源码呢?

640 (4).jpg


昨天我在一个群里有一个人在问,谁会 rxjs?我当时其实还有点好奇,对于 rxjs 我一直觉得很难,前阵子我也一直在研究。


Rxjs 我也一直觉得挺有用的,但是身边用 rxjs 的朋友真的很少,我司的项目也是根本没有。


所以我听到有人问 rxjs 的问题,我就特别激动,就问了他什么问题,他说刚接触 rxjs,然后看源码遇到一端代码看不懂。


我当时心想,还有这种操作的么,还没学会怎么使用就开始看源代码了,然后他就把他不懂的代码贴了上来,rxjs 源码是 TS 写的,我对 TS 不算太熟悉,但是他贴的代码我还是能看懂,他就问了个 this 的问题,我看着也很简单,但是我没有解答他的问题。


原因有两点:


  1. 态度不好,我不喜欢。我跟他说你如何去学习 rxjs 的源码,然后给他介绍书(程墨的《深入浅出 RXJS》)。他直接回复我,你会不会,我就想知道这个问题,不知道就别 BB(大概就是这意思),所以我直接回了他,不会。


  1. 自以为是。他问的问题其实很简单,虽然 Rxjs 源码是 TS 写的,我对 TS 也不是很熟悉,但是这点代码我觉得还是比较简单的,然而这没看懂,然后还在没有上手怎么使用,就开始搞源码,还不听人建议,这纯属自以为是,觉得看源码才是王道。对于这种纯属基础没打好,就开始搞高端的,走都没学会就想学跑。


那么我们如何正确的学习一个框架,什么时候该看源码,学到什么程度再看源码呢?

我觉得学习一个框架应该分为三个程度。


  1. 学会使用


  1. 熟悉框架的设计思想、关键部分的实现思路以及整个框架的知识体系


  1. 源码解读以及造轮子


我以学习 React 为例来介绍如何学习一门框架(库)


学会使用


这个程度我相信是大部分人所处的阶段,熟练使用 React 的 API,熟悉 JSX,各个声明周期的使用,以及组件之间(父子、子父、兄弟等)如何传递消息,高阶组件等。


这就相当于入了门,可以完成一般的业务了。


熟悉框架的设计思想、关键部分的实现思路以及整个框架的知识体系


设计思想


众所周知,React 是一种组件化的解决 UI 构建的一种方案,横向比较同类型的 Vue ,也是组件化的一种解决方案(这体现了 react 抽象的设计思想),既然是组件化的思想,那么这种解决方案,理论上都会有组件的生命周期,来处理组件从创建到销毁的钩子函数。


React 也是一种声明式的解决方案,通过数据驱动来改变 UI,从而有 UI = f(state)。


当然 react 还有其他的设计思想,比如组合(各个小组件的组合成大的页面,这些小组件都是通过组合来达到复用的效果),单向数据流。


关键部分的实现思路


React 的重点概念有 JSX,虚拟 DOM,Diff 算法,setState 机制,这些重点概念自己是否能有他们的实现思路,甚至在没有看源码的情况下是否能自己根据思路实现出来。


这个可以看看胡子大叔写的blog,[从零开始实现一个React](GitHub - hujiulong/blog: 我的blog)。


整体框架的知识体系


已经能熟练使用,也掌握了改框架的重点知识,是否能梳理出整个框架的知识体系,把每个知识点串起来,形成一张 react 知识网,网的每个节点都是一个知识点,连线就是他们之间的关系。


这个阶段基本上应付面试没啥问题了。


源码解读以及造轮子


这个源码解读基本上可以看做终极奥义了,其实大多数情况并没有必要去解锁这个终极奥义,因为源码解读确实比较费时间,特别是对于基础不牢固的同学,看几行代码就有看不懂的,又得去查资料搞懂。


对于文章开头提到的那种行为真的不提倡,作为一个前端,要学的知识那么多,每个都去看源码实现,哪里有那么多时间,不如好好想想怎么用现有的知识更好的去解决业务问题。


然后明白技术是为业务服务的,如果没有业务,技术将是无稽之谈。然而在我们大多数场景下,我们的业务是没有必要去造个轮子来解决,因为对于 react、vue 这种库来说,已经是非常的通用了,能解决 95% 以上的业务。


当然也有这些开源框架解决不了的问题,比如我有个业务是需要写一套代码,多端可以用的,比如写 vue 代码,这套代码也可以转换为 小程序代码,甚至是 Android 原生 、IOS 原生代码等,那么这个时候我们就必须得去看源码,才能更清晰的知道源码是怎么去处理每一个细节,才能造出更强大的轮子。


目录
相关文章
|
网络协议 Windows
【报错】在浏览器输入localhost无法显示想要的内容
【报错】在浏览器输入localhost无法显示想要的内容
469 0
|
前端开发 Java 开发者
深入理解Spring Boot中的@Service注解
【4月更文挑战第22天】在 Spring Boot 应用开发中,@Service 注解扮演着特定的角色,主要用于标识服务层组件。本篇技术博客将全面探讨 @Service 注解的概念,并提供实际的应用示例,帮助开发者理解如何有效地使用这一注解来优化应用的服务层架构
3002 1
|
运维 监控 Java
nacos常见问题之获取配置文件的时候报错user not found如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
2766 2
【Vite】Vite设置好了Proxy,但接口却404!解决方案来了!
前言 最近在做一个Vue3+Vite+TypeScript的项目,进行一番网上冲浪后,参考了众多🐴友的方案,配置完vite.config.ts准备开始与后端的同学开始联调,发现无论怎么样都是404,然后就开始了一步步的排查!
6419 0
|
Go 调度 开发者
Go语言中的并发编程:深入理解与实践###
探索Go语言在并发编程中的独特优势,揭秘其高效实现的底层机制。本文通过实例和分析,引导读者从基础到进阶,掌握Goroutines、Channels等核心概念,提升并发处理能力。 ###
|
10月前
|
存储 前端开发 数据可视化
Grafana Loki,轻量级日志系统
本文介绍了基于Grafana、Loki和Alloy构建的轻量级日志系统。Loki是一个由Grafana Labs开发的日志聚合系统,具备高可用性和多租户支持,专注于日志而非指标,通过标签索引而非内容索引实现高效存储。Alloy则是用于收集和转发日志至Loki的强大工具。文章详细描述了系统的架构、组件及其工作流程,并提供了快速搭建指南,包括准备步骤、部署命令及验证方法。此外,还展示了如何使用Grafana查看日志,以及一些基本的LogQL查询示例。最后,作者探讨了Loki架构的独特之处,提出了“巨型单体模块化”的概念,即一个应用既可单体部署也可分布式部署,整体协同实现全部功能。
3805 70
Grafana Loki,轻量级日志系统
|
JSON API 数据安全/隐私保护
淘宝评论API接口操作步骤详解,代码示例参考
淘宝评论API接口是淘宝开放平台提供的一项服务,通过该接口,开发者可以访问商品的用户评价和评论。这些评论通常包括评分、文字描述、图片或视频等内容。商家可以利用这些信息更好地了解消费者的需求和偏好,优化产品和服务。同时,消费者也可以从这些评论中获得准确的购买参考,做出更明智的购买决策。
|
测试技术 开发者 Python
使用Python解析和分析源代码
本文介绍了如何使用Python的`ast`模块解析和分析Python源代码,包括安装准备、解析源代码、分析抽象语法树(AST)等步骤,展示了通过自定义`NodeVisitor`类遍历AST并提取信息的方法,为代码质量提升和自动化工具开发提供基础。
1054 9
|
JSON API 开发者
淘宝商品评价API的获取与应用
在数字化时代,电商平台如淘宝成为消费者购物的主要渠道。本文介绍如何使用淘宝开放平台的商品评论API获取并利用评论数据,以优化产品和服务,提升用户体验。内容涵盖API的重要性、准备工作、调用流程及代码实现,帮助开发者高效获取和分析数据。
383 3
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
535 2