百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

深入浅出掌握React 与 React Native这两个框架

ccwgpt 2024-09-14 00:27 24 浏览 0 评论



转载链接:https://www.jianshu.com/p/11fe9401874c

此系列文章将整合我的 React 视频教程与 React Native 书籍中的精华部分,给大家介绍 React 与 React Native 结合学习的方法。

1. 软件开发语言与框架的学习本质

我们在开始系列文章的技术点内容前,花一点时间探讨一下软件开发语言以及框架的学习本质,相对于整个技术点的讲解,花这一点一起思考的时间是值得的。

相信看此系列文章的朋友都已有了非常多的软件开发经验,而当我们回顾语言与框架的学习过程时,所有语言的基础语法都大同小异,无非基础数据类型、条件判断、分支判断、循环处理等等。而差别或者说最重要的是在框架的底层本质,也就是为什么会产生此框架、底层的优势是什么、为什么不用别的框架、框架的底层与设备之间是如何实现通信的等等。

截图

我们在开发的过程中,遇到的一些基础语法问题、框架使用问题,基本上只要灵活使用一下搜索引擎都能找到答案,有句话说:你要相信你遇到的技术难题在这个世界上肯定有其他人也遇到了。

而当我们需要抓住本质,对语言与框架有更加深入地了解、进行技术选型时、知道每一种技术的优劣、当框架的表现出现了一些诡异问题时会迅速定位问题、优化项目的性能,以及成为某一领域的专家时,最高效的学习方法就是直接去接触语言与框架的底层本质。

如 JavaScript 中的深拷贝与浅拷贝,如果只是进行数据类型的深拷贝与浅拷贝,即使你忘记了处理逻辑,你只要通过搜索引擎搜索就可以找到很多的实现方法,而如果你想一次掌握好此知识点,那么就需要你直接去学习数据结构以及数据类型对应的值类型与引用类型的区别,只有在掌握此部分的知识点后,在遇到数据类型的「诡异」表现时你才能抓住问题本质。

再如你在使用 React Native 框架提供的各种组件与 API,如访问移动设备的相册与摄像头、震动、GPS 定位、网络状态、消息推送以及整个 React Native 框架生态下提供的成千上万的第三方功能组件时,其实底层都是 React Native 框架与 iOS、Android 平台通信的实现。在原理章节掌握了原理后,后续的章节我们还会一起自己动手来实现一个与 iOS、Android 平台通信的自定义组件。

学习、精通语言与框架最好的方法就是直接掌握其最本质的部分。

2. React 与 React Native 框架简介

React 框架最早孵化于 Facebook 内部,作为内部使用的框架,在 2011 年的时候 React 框架被用于 Facebook 的新闻流并于 2012 年使用在了 Instagram 项目上。在 2013 年五月美国的 JSConf 大会上,React 框架项目被宣布了开源。

在移动开发方面,Facebook 曾致力于使用 HTML 5 进行移动端的开发,最终发现与原生的 App 相比,体验上还是有非常大的差距,并且这种差距越来越大,特别是性能方面的差距。 最终,Facebook 放弃了 HTML 5 的技术方向,结合之前介绍的 React 框架的发展历史,2015 年 3 月,Facebook 正式发布了 React Native 框架,此框架专注于移动端 App 的开发。

React 作为构建高性能 Web 应用的框架,React Native 作为构建跨 iOS 与 Android 平台 App 应用的框架,极其繁杂的开发生态造成了很多朋友对 React / React Native 框架产生了些许误解,认为框架太过庞杂混乱,造成了学习成本与开发成本的增加。

此系列文章将带领大家深入探究 React 与 React Native 框架的本质,只有在掌握了框架本质后,才能快速地领略到这两个孪生框架的核心,不仅可以在这两个框架间灵活切换学习,还可以不被繁杂的框架生态所蒙蔽,最终达到以不变应万变的境界。

3. 将 React 与 React Native 结合在一起学习

从上面的 React 与 React Native 简介即可看到,两个框架算是孪生项目,而 React Native 的底层也就是 React 框架。

截图

React 框架使用 JSX(JavaScript eXtension,可以理解为看起来像 HTML 的 JavaScript)指定 React 组件的输出定义,而逻辑函数的部分依然是采用 JavaScript ES6 来编写,所以对于前端开发人员来说上手非常地容易。

编写的代码通过 React 框架渲染在 Web 浏览器中运行,所以 React 可以用来开发 Web 项目,当然借助第三方的组件还可以开发桌面项目,这些我们在后续会进行相关介绍。

React Native 依然由 JSX 进行组件布局的开发,框架中组件开发的原理与思想与 React 框架一致,而且底层都由最重要的 state 进行驱动。

React 与 React Native 除了在编码表现层都使用 JSX 语法外,在 React 与 React Native 的底层都有 Virtual DOM 与 DOM 之间的映射与转换,以实现了页面组件高效更新的前端表现。

截图

用户看到的表现层(Browser DOM)的更新,底层都是由 state 驱动了 Virtual DOM 进行变动前与变动后的比较,最终将需要重新渲染的 DOM 进行渲染展示。

而这种通过只修改 state (Model) 值引起 HTML (DOM) 变化的框架设计模式就是我们熟悉的 MVVM (Model-View-ViewModel) 模式。

以前我们可以通过直接操作 HTML 元素的形式进行页面的更新,如下面的这段 jQuery 代码。

$('#container').text('Updated Content...')

当这样的代码在页面更新非常复杂的项目中使用时,你会疲于通过操作 DOM 元素更新,映射后台大量的数据更新。

截图

而 MVVM 模式,如目前的前端框架 Vue、Angular 和我们介绍的 React 都是基于此设计模式,将页面呈现 View 与后台的数据模型 Model 进行了分离解耦,使得我们只需要专注于 Model 的处理,通过修改 Model 中的属性值,引起前端 View 的变化,不过 React 默认的数据绑定方式是单向绑定,这一部分的差异我们后续章节会展开讨论。

对于 MVVM 模式的体验以及如何通过修改 Model 引起 View 的更新,大家可以查看下一小节,我会给大家具体的代码演示。

而目前的移动端开发方面,「原生开发」是指 iOS 平台通过 Objective-C 或 Swift 语言开发并通过 Xcode 编译打包发布 iOS App,Android 平台通过 Java 语言开发并通过 Android Studio 编译打包发布 Android App。

通过下图我们可以看到「原生开发」的学习成本以及后期 App 维护的成本,而 React Native 则是通过 JavaScript 开发,然后通过框架提供的与对应平台之间的 bridge 进行通信,实现了只用一套代码可以直接部署到 iOS 与 Android 平台并编译出对应平台的 App。

截图

并且 React Native App 页面布局直接通过 HTML 和 CSS 的前端基础技术进行布局与开发,大大降低了学习成本。

你如果早就在心里有开发一个自己 App 的想法,而刚好你有前端开发的技能,React Native 一定会是你孵化自己 App 最好的选择。

4. 系列文章的内容范围

本系列文章会从 React 的基本使用方法开始,并会讲解到 React 的底层原理,并从一些实际案例中探讨出 React 底层对于前台表现的原因。底层原理会结合独立的算法以及 React 框架的源码进行详细解释。

之后会讲解演示 React Native 的基本使用,同时会解释 React Native 框架与 React 框架的关系、React Native 的性能问题、以及 React Native 与 iOS、Android 平台通信的原理,抛却 React Native 纷杂的各种类库,直达 React Native 的底层原理,掌握了原理后才能看懂所有表象的类库实现原理。并会动手自己实现 iOS 平台与 Android 平台的自定义组件,深入掌握各种第三方组件的实现原理。

「React.js 入门与实战」视频教程

《React Native 精解与实战》书籍

更多免费原创视频教程

需要相关资料,关注我,私信我回复:React和React Native 学习资料


5. 小结

这一小节给大家描绘了整体安排以及学习的本质,接下来我们会先从 React 底层原理开始,掌握好这两个框架最本质的部分。

任何知识的学习过程都不会是「舒服」的过程,只有跳离自己的舒适区,才能有进步,所以遇到任何疑问或想交流的问题,大家只需在文章下留言即可,我都会与大家交流。


相关推荐

迈向群体智能 | 智源发布首个跨本体具身大小脑协作框架

允中发自凹非寺量子位|公众号QbitAI3月29日,智源研究院在2025中关村论坛“未来人工智能先锋论坛”上发布首个跨本体具身大小脑协作框架RoboOS与开源具身大脑RoboBrain,可实...

大模型对接微信个人号,极空间部署AstrBot机器人,万事不求百度

「亲爱的粉丝朋友们好啊!今天熊猫又来介绍好玩有趣的Docker项目了,喜欢的记得点个关注哦!」引言前两天熊猫发过一篇关于如何在极空间部署AstrBot并对接QQ消息平台的文章,不过其实QQ现在已经很少...

Seata,让分布式事务不再是难题!实战分享带你领略Seata的魅力!

终身学习、乐于分享、共同成长!前言Seata是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务。Seata将为用户提供了AT、TCC、SAGA和XA事务模式,为用户打造一站式的...

常见分布式事务解决方案(分布式事务解决的问题)

1.两阶段提交(2PC)原理:分为准备阶段(协调者询问参与者是否可提交)和提交阶段(协调者根据参与者反馈决定提交或回滚)。优点:强一致性,适用于数据库层(如XA协议)。缺点:同步阻塞:所有参与者阻塞...

分布式事务:从崩溃到高可用,程序员必须掌握的实战方案!

“支付成功,但订单状态未更新!”、“库存扣减后,交易却回滚了!”——如果你在分布式系统中踩过这些“天坑”,这篇文章就是你的救命稻草!本文将手把手拆解分布式事务的核心痛点和6大主流解决方案,用代码实战+...

谈谈对分布式事务的一点理解和解决方案

分布式事务首先,做系统拆分的时候几乎都会遇到分布式事务的问题,一个仿真的案例如下:项目初期,由于用户体量不大,订单模块和钱包模块共库共应用(大war包时代),模块调用可以简化为本地事务操作,这样做只要...

一篇教你通过Seata解决分布式事务问题

1 Seata介绍Seata是由阿里中间件团队发起的开源分布式事务框架项目,依赖支持本地ACID事务的关系型数据库,可以高效并且对业务0侵入的方式解决微服务场景下面临的分布式事务问题,目前提供AT...

Seata分布式事务详解(原理流程及4种模式)

Seata分布式事务是SpringCloudAlibaba的核心组件,也是构建分布式的基石,下面我就全面来详解Seata@mikechen本篇已收于mikechen原创超30万字《阿里架构师进阶专题合...

分布式事务最终一致性解决方案有哪些?MQ、TCC、saga如何实现?

JTA方案适用于单体架构多数据源时实现分布式事务,但对于微服务间的分布式事务就无能为力了,我们需要使用其他的方案实现分布式事务。1、本地消息表本地消息表的核心思想是将分布式事务拆分成本地事务进行处理...

彻底掌握分布式事务2PC、3PC模型(分布式事务视频教程)

原文:https://mp.weixin.qq.com/s/_zhntxv07GEz9ktAKuj70Q作者:马龙台工作中使用最多的是本地事务,但是在对单一项目拆分为SOA、微服务之后,就会牵扯出分...

Seata分布式事务框架关于Annotation的SAGA模式分析

SAGAAnnotation是ApacheSeata版本2.3.0中引入的功能,它提供了一种使用Java注解而不是传统的JSON配置或编程API来实现SAGA事务模式的声明...

分布式事务,原理简单,写起来全是坑

今天我们就一起来看下另一种模式,XA模式!其实我觉得seata中的四种不同的分布式事务模式,学完AT、TCC以及XA就够了,Saga不好玩,而且长事务本身就有很多问题,也不推荐使用。S...

内存空间节约利器redis的bitmap(位图)应用场景有哪些你知道吗

在前面我们分享过一次Redis常用数据结构和使用场景,文章对Redis基本使用做了一个简单的API说明,但是对于其中String类型中的bitmap(位图)我们需要重点说明一下,因为他的作用真的不容忽...

分布式事务原理详解(图文全面总结)

分布式事务是非常核心的分布式系统,也是大厂经常考察对象,下面我就重点详解分布式事务及原理实现@mikechen本文作者:陈睿|mikechen文章来源:mikechen.cc分布式事务分布式事务指的是...

大家平时天天说的分布式系统到底是什么东西?

目录从单块系统说起团队越来越大,业务越来越复杂分布式出现:庞大系统分而治之分布式系统所带来的技术问题一句话总结:什么是分布式系统设计和开发经验补充说明:中间件系统及大数据系统前言现在有很多Java技术...

取消回复欢迎 发表评论: