React、Umi、RN 整体理解

这篇具有很好参考价值的文章主要介绍了React、Umi、RN 整体理解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

可以少去理解一些不必要的概念,而多去思考为什么会有这样的东西,它解决了什么问题,或者它的运行机制是什么?

React

1. React 起源和发展(是什么?)

React 是用于构建用户界面的 JavaScript 库,起源于 Facebook 的内部项目,该公司对市场上所有 JavaScript MVC 框架都不满意,决定自行开发一套,用于架设 Instagram 的网站。于2013年5月开源。

React 与传统 MVC 的关系:

React 并不是一个完整的框架,最多认为是 MVC 中的 V (View),即 React 一般被用来作为 MVC 中的 V 层。做为 V 层构建用户 UI 的库,可以简单的理解为,React 将页面分成了各个独立的小块,每一个小快就是一个组件,这些组件之间可以组合、嵌套,就成了我们的页面。

它不依赖其他任何的库,在开发中,可以与任何其他的库集成使用,包括 Jquery。React 的思想非常独特,性能出众,可以写出重复代码少,逻辑清晰的前端代码。它可以在浏览器端运行,也可以通过 nodejs 在服务端渲染。

2. React 的特性

  1. 声明式设计:React 采用声明范式,可以轻松描述应用。

    React 使创建交互式 UI 变得轻而易举。为你应用的每一个状态设计简洁的视图,当数据变动时 React 能高效更新并渲染合适的组件。以声明式编写 UI,可以让你的代码更加可靠,且方便调试。

  2. 高效(虚拟 DOM):React 通过对 DOM 的模拟使用了虚拟 DOM,可以最大限度地减少与真实 DOM 的交互。

  3. 灵活:React 不依赖其他任何的库,在开发中 React 可以与已知的库或框架很好地配合。

  4. 组件化:通过 React 构建组件,使得代码更加容易得到复用(复用复用复用),能够很好的应用在大项目的开发中。

    构建管理自身状态的封装组件,然后对其组合以构成复杂的 UI。由于组件逻辑使用 JavaScript 编写而非模板,因此你可以轻松地在应用中传递数据,并保持状态与 DOM 分离。

  5. 单向响应的数据流:React 实现了单向响应的数据流,从而减少了重复代码,这也是它为什么比传统数据绑定更简单。

    单向数据流,数据流方向是由从上到下(父到子)的,如果下面子组件数据发生改变(更新)了,要从子组件发送到父组件,父组件更新完了之后再次传递给子组件(也就是说子组件数据更新后,需要父组件重新的给它流入一遍),这个时候父子组件都可以使用这个数据。

    比如说:老板下达任务给下属,然后下属执行。 如果此时下属有个想法(比如修改个某某数据),这时需要请示领导,如果领导同意了,那么下属得到新的命令再去执行。好处就是,所有的主动权都在顶层组件,下面所有的变动上面都知道。如果什么事低下自己决定,直接修改完,告诉上面。出问题调查起来麻烦,不知道上面还是下面出了问题。

  6. JSX: JSX 是 JavaScript 语法的扩展。React 开发不一定使用 JSX ,但我们建议使用它。

    React 的语法是 JSX,通过使用这种语法,可以在 React 代码中直接混合使用 js 和 html、css 来编写组件代码,这样代码的逻辑就非常清晰,当然也意味着,需要将 jsx 代码编译成普通的 javascript 代码,才能在浏览器中运行, 这个过程让 React 中的处理器去解析 JSX 就行了。

  7. 一次学习,跨平台编写:

    无论你现在使用什么技术栈,在无需重写现有代码的前提下,通过引入 React 来开发新功能。React 还可以使用 Node 进行服务器渲染,或使用 React Native 开发原生移动应用。

3. React 的缺点

并不是一个单独完整的框架,React 是目标是 UI 组件,通常可以和其它框架组合使用,目前并不适合单独做一个完整的框架。

4. 什么是虚拟 DOM?

4.1)传统 DOM 更新

真实页面对应一个 DOM 树,在传统的开发中,每次需要修改、更新页面时,都需要手动直接操作 DOM 来进行更新。

4.2)虚拟 DOM

DOM 操作非常昂贵。我们都知道在前端开发中,性能消耗最大的就是 DOM 操作,而且这部分代码会让整体项目的代码变得难以维护。React 把真实的 DOM 树、数据转换成 JavaScript 对象,也就是 Virtual DOM(虚拟 DOM、VDOM、vnode)。也就是说在 React 中用 JS 对象来描述虚拟 DOM 树。

比如在 React 中,render 执行的结果得到的并不是真正的 DOM 节点,而是 Virtual DOM, 即仅仅是轻量级的 JavaScript 对象 。

虚拟 DOM 原理:

React 会基于真实 DOM 和数据创建两条虚拟 DOM ,用 DIFF 算法以最小的代价对比(DIFF)出两个虚拟 DOM 数据节点是不是有改变。从而只选择将需要修改的部分给标记起来,做一个补丁,真正更新到真实的 DOM 中。

不动其他 DOM 只会影响改变的 DOM,其他 DOM 节点不需要重新创建的,只需要调整位置。

React 虚拟 DOM 核心思想:

对复杂的文档 DOM 结构,提供一种方便的工具,进行最小化地 DOM 操作。这句话,也许过于抽象,却基本概况了虚拟 DOM 的设计思想。

虚拟 DOM 总结:

虚拟 DOM 是 React 的一大亮点,具有 batching(批处理)和高效的 Diff 算法。这让我们可以无需担心性能问题而“毫无顾忌”的随时“刷新”整个页面,由虚拟 DOM 来确保只对界面上真正变化的部分进行实际的 DOM 操作。在实际开发中基本无需关心虚拟 DOM 是如何运作的,但是理解其运行机制不仅有助于更好的理解 React 组件的生命周期,而且对于进一步优化 React 程序也会有很大帮助。

虚拟 DOM 实例:

React 会基于真实 DOM 和数据创建两条虚拟 DOM,这里就可以做一个对比:前后两条没有做出改变,中间少了一条,这时候给他标记起来,做一个补丁 patch(s) ,真正更新到真实的 DOM 中。

// 原始基础数据:[111, 222, 333],基于基础数据创建出来的虚拟 DOM 如下:
{
	{
    type:"li",
    text:"111",
  },
  {
    type:"li",
    text:"222",
  },
  {
    type:"li",
    text:"333",
  },
}

// 修改后的数据:[111, 333],基于新的基础数据创建出来的虚拟 DOM 如下:
{
	{
    type:"li",
    text:"111",
  },
  {
    type:"li",
    text:"333",
  },
}

4.3)DOM 直接操作对性能的影响

DOM 直接操作将导致回流重排严重影响性能,比如减少的 Dom 删掉,下面的 Dom 需要往上移,引发文档的重排,回流的问题。频繁改变 DOM 就会导致回流现象,回流就是重新排列下它的顺序,然后重新渲染一遍,就会影响我们的性能。

Umi

Umi,中文可发音为乌米,是可扩展的企业级前端应用框架。Umi 以路由为基础的,同时支持配置式路由和约定式路由,保证路由的功能完备,并以此进行功能扩展。然后配以生命周期完善的插件体系,覆盖从源码到构建产物的每个生命周期,支持各种功能扩展和业务需求。其次 Umi 本身是基于 React 构建的。

create-react-app 是基于 webpack 的打包层方案,包含 build、dev、lint 等,他在打包层把体验做到了极致,但是不包含路由,不是框架,也不支持配置。所以,如果大家想基于他修改部分配置,或者希望在打包层之外也做技术收敛时,就会遇到困难。

React Native

React 是用于构建用户界面的 JavaScript 库,是基于浏览器的。React Native 可以基于目前大热的开源 JavaScript 库 React.js 来开发 iOS 和 Android 原生 App。

React 和 React Native 的区别:

1)框架作用的平台不同

RN 是由 React 衍生出来的,两种框架都是用 JSX 开发语法,但是 RN 是用来开发真正基于原生渲染的 iOS 和 Andriod 移动应用的 JS 框架,而React 是将浏览器作为渲染平台。

2)工作原理的差别

Virtual DOM 是介于开发者描述的视图与实际在页面上渲染的视图之间。在浏览器上如果想渲染出来可交互的用户界面,开发者必须操作浏览器的文档对象(document object model),Virtual DOM 的出现,就是为了节省这部分操作所消耗的性能。但是 Virtual DOM 的巨大潜力,是在于这个抽象层,可以带来很多可能性。

React Native 的工作原理,就是调用 Objective-C 的 API 去渲染 iOS 组件,调用 Java API 去渲染 Android 组件,而不是渲染到 DOM 上。桥接使得 React 可调用宿主平台开放的 UI 组件,React 组件通过 render 方法返回了描述界面的标记代码。如果是 Web 平台,React 最终把标记代码解析成浏览器的 DOM;而在 React Native 中,标记代码会解析成特定平台的组件,例如会表现成 iOS 平台上的 UIView。

3)渲染周期

React 的渲染周期开始于 React 组件挂载到 DOM 之后,接着 React 进入渲染周期并根据需要渲染组件。在渲染阶段,React 将开发者在 return 中返回的 HTML 标记直接按需渲染到页面上。

React Native 生命周期与 React 基本相同,在渲染上因为 React Native 依赖于桥接,并不在 UI 主线程运行,它可以在不影响用户体验的前提下执行这些异步调用。

4)创建组件

当编写 Web 环境的 React 的时候,视图最终需要渲染成普通的 HTML 元素;而在 React Native 中,所有元素都会被平台指定的组件替换,例如在 iOS 中,组件被渲染成 UIView,而在 Android 平台,会被渲染成 View。UI 元素均为 React 的(原生的)组件,而不是基础的 html 元素,因此在使用每一个组件的时候,都需要显式的导入。

5)原生的样式

在 Web 中,使用 CSS 样式为 React 组件添加样式已经是开发过程中不可获取的一部分了。React 通常不影响我们编写 CSS 的方式,并且它确实让样式的动态创建更加容易(通过 state 和 props),除此之外,React 基本上不关心我们如何处理样式的。

非 Web 平台上有大量的方法来处理布局和样式,我们使用 React Native 时,只需要用一种标准的方法来处理样式,React 和宿主平台之间的桥接包含了一个缩减版 CSS 子集的实现,这个 CSS 子集主要通过 flexbox 进行布局,做到了尽量简化,而不是去实现所有的 CSS 规则。有别于 Web 平台,CSS 的支持程度因浏览器而不同,React Native 则做到了样式规则的一致。

6)宿主平台 Api

使用 Web 环境的 React 与 React Native 最大的不同,在于宿主平台的 Api。

在 Web 中,我们通常要处理采纳标准的不一致和碎片化所引起的问题,并且大多数浏览器只支持部分核心的特性。然而在 React Native 中,平台特定的 Api 在提供优秀原生的用户体验方面发挥了巨大的作用。当然,要考虑的方面还有很多。Api 囊括了许多功能,从数据存储到地理服务,以及操控硬件设备(如摄像头)等。非常规平台上的 Api 会更有趣,例如,React Native 和虚拟现实头盔之间的 API 会是什么样的呢?

默认情况下,iOS 和 Android 版本的 React Native 支持许多常用的特性,甚至可以支持任何异步的本地 Api。React Native 让宿主平台 Api 的使用变得更加简单和直观,你可以在其中自由地试验。同时,务必思考一下怎样做才符合目标平台的体验,并在心里设计好交互过程。毋庸置疑,React Native 的桥接不可能暴露宿主平台全部的 Api。

如果你需要使用一个未支持的特性,完全可以自己动手添加到 React Native 中。另外,如果其他人已经集成,那就更好了,所以应该及时查看社区中的实现。值得注意的是,使用平台 Api 也会对代码复用有帮助。同时,实现平台特定功能的 React 组件也是平台特定的。

隔离和封装这些组件将会给你的应用带来更大的灵活性。当然,这对你开发 Web 应用同样奏效,如果你想共享 React 和 React Native 的代码,请记住像 DOM 这样的 API 在 React Native 中并不存在。文章来源地址https://www.toymoban.com/news/detail-746320.html

到了这里,关于React、Umi、RN 整体理解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • react umi/max 封装页签组件

    思路:封装一个页签组件,包裹页面组件,页面渲染之后把数据缓存到全局状态实现页面缓存。 浏览本博客之前先看一下我的博客实现的功能是否满足需求,实现功能: - 页面缓存 - 关闭当前页 - 鼠标右键关闭当前 - 鼠标右键关闭其他 - 鼠标右键关闭左侧 - 鼠标右键关闭右侧

    2024年01月18日
    浏览(42)
  • react umi中使用svg线上图片不加载问题

    参考链接: https://www.jianshu.com/p/c927122a6e82 前言: 在react项目中,我们本地通过img标签的src使用svg图片是可以加载的,但是发布到线上图片加载不出来。 解决方案 方案一 使用场景:直接在当前页面引入svg图片 有一个 svgr 插件,是支持以 react component 的方式,引入 svg 图片的。

    2024年02月11日
    浏览(38)
  • 接口测试 再也不必来回切换,发现一个接口测试软件,可以替代 Swagger+Mock+Jmeter+Postman

    日常测试过程中,常常需要多种工具来接力完成自己的接口测试任务。 比如说, 使用swagger查看接口文档, 使用mock编造接口数据对前端页面做测试 使用postman测试后端接口, 用Jmeter来做接口自动化测试/性能测试。 那有没有一款软件可以完美集成以上所有的功能? 笔者发现

    2024年02月15日
    浏览(59)
  • 微前端使用qiankun实现,react主应用同时兼顾react,vue3,umi子应用

    理解 :我们可以简单理解为微前端是将一个项目拆分成多个模块,每个微前端模块可以由不同的团队进行管理,并可以自主选择框架,并且有自己的仓库,可以独立部署上线 应用场景 :1.当公司代码较老需要使用新的技术栈时我们可以使用微前端。2.多个团队同时开发时,每

    2024年02月09日
    浏览(63)
  • React-Native学习,RN的容器Flex-Box布局

    justify-content(在RN中属性名称为:justifyContent)在主轴上对齐方式 align-items(在RN中属性名称为:alignItems)在交叉轴上的对齐方式 在React Native中,当没有设置容器的主轴方向时,默认容器主轴方向为:flexDrection: \\\'column\\\',也就是说,当我们的容器的主轴的排布方向为竖直方向时

    2024年02月16日
    浏览(54)
  • react--umi, 根据权限展示菜单,完成页面权限分配,以及路由鉴权

           umi框架,prolayout布局,access设置菜单权限,initialState全局初始化数据,配合使用,根据后端返回的权限信息,完成菜单的不同的权限的不同展示。     1. umi 配合 patlayout 布局, 实现根据配置的路由展示菜单栏     2. umi 的 access 插件,设置不同权限的菜单展示    

    2024年02月06日
    浏览(91)
  • [快速上手RN] 3. React native 制作底部导航栏 Bottom Tab Bar

    [快速上手RN] 0.React Native 快速启动项目 [快速上手RN] 1. React native 项目集成UI Kitten [快速上手RN] 2. React native 项目色彩主题色编辑及使用 [快速上手RN] 3. React native 制作底部导航栏 Bottom Tab Bar [快速上手RN] 4. React native 集成redux 首先我们确认目标 在APP底部新增一个导航栏 导航栏点

    2024年02月05日
    浏览(53)
  • 推荐用于学习RN原生模块开发的开源库—react-native-ble-manager

    如题RN的原生模块/Native Modules的开发是一项很重要的技能,但RN官网的示例又比较简单,然后最近我接触与使用、还有阅读了react-native-ble-manager的部份源码,发现里边完全包含了一个Native Modules所涉及的知识点/技术点,故特推荐给大家,共同学习与交流 react-native-ble-manager目前

    2024年02月15日
    浏览(51)
  • 求助帖:React Native failed installing Ruby Gems(rn 下载 Runby Gems 失败)

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 react native当前版本0.72.4,官方文档也是最新的, macos:13.3。 最近要用RN做一个项目,参照官方文档链接: link 已经完成了前期的配置工作,直到最后一步创建AsomeProject示例项目时候,RN下载依赖卡在Inst

    2024年02月07日
    浏览(46)
  • React16源码: React中的schedule调度整体流程

    schedule调度的整体流程 React Fiber Scheduler 是 react16 最核心的一部分,这块在 react-reconciler 这个包中 这个包的核心是 fiber reconciler,也即是 fiber 结构 fiber 的结构帮助我们把react整个树的应用,更新的流程,能够拆成每一个 fiber 对象为单元的一个更新的流程 这种单元的形式把更新

    2024年01月19日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包