前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >react-naive工作原理

react-naive工作原理

作者头像
甜点cc
发布于 2023-10-16 07:02:53
发布于 2023-10-16 07:02:53
2710
举报

react-naive工作原理是从react的工作原理衍生出来的

react的工作原理

在react中,virtual dom 就像一个中间层,介于开发者描述的视图与实际在页面上渲染的视图之间。为了在浏览器上渲染出可交互的用户界面,开发者必须操作浏览器的Dom,这个操作代价昂贵,过度操作dom会给性能带来影响。React 维护了一个内存版本的 DOM,通过计算得出必要的最小操作并重新渲染。如下图:

执行 vdom 的计算(dom diff),减少浏览器DOM的重复渲染 对于 Web 环境的react而言,大多数开发者认为 virtual dom 的出现主要是为了优化性能。vdom确实能提升性能,但它的主要潜力在于提供了强大的抽象能力。在开发者的代码与实际的渲染之间加入一个抽象层,这带来了很多可能性。稍微想象一下,如果react能够渲染到浏览器以外的其他平台呢?毕竟,react已经“理解”了你的应用应该如何展现。

React Native 的工作原理

如下图,这就是 React Native 的工作原理。 react native 调用Objective-CAPI去渲染iOS组件,调用Java接口去渲染Android组件,而不是渲染到浏览器的DOM上,这使得react native 不同于那些基于web视图的跨平台应用开发方案(各种小程序 uniapp\taro , 适配器转化)。

react可以渲染到多个平台

Bridge"桥接"使这一切成为可能,它使得react可以调用宿主平台开放的UI组件。react组件通过render方法返回了描述界面的标记代码。

  1. web平台: react最终将标记代码解析成浏览器的dom
  2. react native中:标记代码会被解析成特定平台的组件
    1. <View>组件将会表现为iOS平台的UIView

react native 目前同时支持iOS和Android两种平台。由于virtual DOM提供了抽象层,react native也可以支持其他平台,只需要提供“桥接”即可。

react 和 react native 的不同点

框架作用的平台不同

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

工作原理不同

上面总结的工作原理

渲染周期

react 组件挂载过程 -> 重新渲染过程。

  1. React的渲染周期开始于react组件挂载到DOM之后,接着React进入渲染周期并根据需要渲染组件。在渲染阶段,React将开发者在return中返回的HTML标记直接按需渲染到页面上
  2. React Native生命周期与React基本相同,在渲染上因为React Native依赖于桥接,并不在UI主线程运行,它可以在不影响用户体验的前提下执行这些异步调用。

创建组件

当编写Web环境的React的时候,视图最终需要渲染成普通的HTML元素;

而在React Native中,所有元素都会被平台指定的React组件替换,例如在iOS中,<View>组件被渲染成UIView,而在Android平台,会被渲染成View

原生的样式

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

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

宿主平台接口

数据存储、地理服务、操控硬件设备

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-05-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
JavaScript 是如何工作的:编写自己的 Web 开发框架 + React 及其虚拟 DOM 原理
Proxy 允许我们创建一个对象的虚拟代理(替代对象),并为我们提供了在访问或修改原始对象时,可以进行拦截的处理方法(handler),如 set()、get() 和 deleteProperty() 等等,这样我们就可以避免很常见的这两种限制(vue 中):
前端小智@大迁世界
2019/03/15
1.2K0
JavaScript 是如何工作的:编写自己的 Web 开发框架 + React 及其虚拟 DOM 原理
这个库让JavaScript变“懒”了,但性能飞升啦
尤其是在一些业务比较复杂的场景,原生 JavaScript 实现可能很啰嗦,但使用第三方工具库,通常一行代码就搞定了。
程序员老鱼
2023/09/07
2400
这个库让JavaScript变“懒”了,但性能飞升啦
Java学习笔记-全栈-web开发-03-JavaScript基础
在javascript中使用 var 运算符(variable 的缩写)加变量名定义的。
devi
2021/08/18
7360
前端学习之JavaScript
尽管 ECMAScript 是一个重要的标准,但它并不是 JavaScript 唯一的部分,当然,也不是唯一被标准化的部分。实际上,一个完整的 JavaScript 实现是由以下 3 个不同部分组成的:
超蛋lhy
2018/08/31
1.7K0
前端学习之JavaScript
重新介绍 JavaScript(JS全面系列教程)
为什么会有这一篇“重新介绍”呢?因为 JavaScript 堪称世界上被人误解最深的编程语言。虽然常被嘲为“玩具语言”,但在它看似简洁的外衣下,还隐藏着强大的语言特性。 JavaScript 目前广泛应用于众多知名应用中,对于网页和移动开发者来说,深入理解 JavaScript 就尤有必要。
ihoey
2018/10/31
1.7K0
全面理解面向对象的 JavaScript
前言 当今 JavaScript 大行其道,各种应用对其依赖日深。web 程序员已逐渐习惯使用各种优秀的 JavaScript 框架快速开发 Web 应用,从而忽略了对原生 JavaScript 的学习和深入理解。所以,经常出现的情况是,很多做了多年 JS 开发的程序员对闭包、函数式编程、原型总是说不清道不明,即使使用了框架,其代码组织也非常糟糕。这都是对原生 JavaScript 语言特性理解不够的表现。要掌握好 JavaScript,首先一点是必须摒弃一些其他高级语言如 Java、C# 等类式面向对象思
庞小明
2018/03/07
1.1K0
全面理解面向对象的 JavaScript
JavaScript基础
脚本语言,语法类似于java(脚本语言又被称为扩建的语言,或者动态语言,是一种编程语言,用来控制软件应用程序,脚本通常以文本(如ASCII)保存,只在被调用时进行解释或编译。)
xiaozhangStu
2023/05/04
3650
你不知道的 JavaScript 中卷(1、类型)
最近在读《你不知道的 JavaScript 中卷》,不会像上卷那样通篇仔细阅读一章一章的写博客了,因为我没那么多精力了。我每天花一点时间去写一些简单且篇幅不长的博客,这样在地铁或在电梯里花一分钟就可以读完。
Karl Du
2023/10/20
3170
百度Web前端技术学院(2)-JavaScript 基础
百度前端学院的第二次任务笔记,JavaScript 基础。主要有JavaScript的定义,数据类型,对象,数组,字符串,正则表达式,DOM,事件,BOM,Ajax 等知识。
零式的天空
2022/03/22
2.1K0
百度Web前端技术学院(2)-JavaScript 基础
Backbone.js
注:教程请参见这里(本文有很多内容都是从这里翻译的),官方网站在这里;综合例子参见这里。
四火
2022/07/15
9580
Backbone.js
老雷微信小程序教程之开发框架学习
1.全局配置 小程序根目录下的 app.json 文件用来对微信小程序进行全局配置。
老雷PHP全栈开发
2020/07/02
3550
lodash 是如何做类型检测的
JS 的基本数据类型有 Number,String,Boolean,Symbol,Null,Undefined,六种数据类型。一种引用类型 object。
Javanx
2019/09/04
1.7K0
lodash 是如何做类型检测的
看完这几道 JavaScript 面试题,让你与考官对答如流(中)
IIFE或立即调用的函数表达式是在创建或声明后将被调用或执行的函数。 创建IIFE的语法是,将function (){}包裹在在括号()内,然后再用另一个括号()调用它,如:(function(){})()
前端小智@大迁世界
2022/06/15
2K0
面向 JavaScript 开发人员的 ECMAScript 6 指南(4):标准库中的新对象和类型
在之前的 3 篇文章中,介绍了 ECMAScript 6 规范给 JavaScript 带来的一些巨大变化。如果您一直在关注本系列文章,那么您应该已经尝试了一些 语法变化,发现了新的 箭头函数 的函数式特性,还试验过在 JavaScript 程序中使用传统的 类语法。如果您像我一样,当您发现 ECMAScript 技术委员会在努力对大家最喜欢的拥有 20 年历史的脚本语言进行了重大变更,同时并没有牺牲它的易用性或基于原型的对象系统,那么您很可能会感到宽慰。
疯狂的技术宅
2019/03/28
6460
深入理解 JavaScript Prototype 污染攻击
本来是想发在代码审计知识星球里的一篇科普文章,因为最近知识星球似乎在和神秘组织对接,无法发表内容,所以发在博客里。Code-Breaking官方writeup拖了很久,主要是没时间,不过外面已经有很多同学的writeup了,所以问题不大。
phith0n
2023/10/28
2650
深入理解 JavaScript Prototype 污染攻击
面向 JavaScript 开发人员的 ECMAScript 6 指南(2):ECMAScript 6 中的函数增强
第 2 部分专门介绍将改变您使用 JavaScript 中的函数的方式的语言更新。在这一部分中,我们将介绍函数定义和调用语法,您将进一步了解解构赋值(这一次在函数定义中)。我还将介绍新的箭头函数语法和生成器函数,后者给经典的迭代器和古老的for 循环带来了有趣的转机。
疯狂的技术宅
2019/03/28
7280
JavaScript 中 10 个需要掌握基础的问题
JavaScript 是一种客户端编程语言。 全球超过90%的网站都在使用它,它是世界上最常用的编程语言之一。 因此,今天我们业讨论 10 个有关 JavaScript 的常见问题。
前端小智@大迁世界
2020/10/23
2.8K0
Web前端-JavaScript基础教程上
JavaScript是web前端开发的编程语言,大多数网站都使用到了JavaScript,所以我们要进行学习,JavaScript是必备的前端技能。
达达前端
2019/07/03
2.2K0
Web前端-JavaScript基础教程上
JavaScript
    1996年11月,JavaScript的创造者--Netscape公司,决定将JavaScript提交给国际标准化组织ECMA,希望这门语言能够成为国际标准。次年,ECMA发布262号标准文件(ECMA-262)的第一版,规定了浏览器脚本语言的标准,并将这种语言称为ECMAScript,这个版本就是1.0版。
changxin7
2022/05/06
1.3K0
JavaScript
Web-第三天 JavaScript学习【悟空教程】
用户在提交表单时,需要对用户的填写的数据进行校验。本案例只对用户名、密码、确认密码和邮箱进行校验。
Java帮帮
2018/07/27
3.4K0
Web-第三天 JavaScript学习【悟空教程】
推荐阅读
相关推荐
JavaScript 是如何工作的:编写自己的 Web 开发框架 + React 及其虚拟 DOM 原理
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文