位置: 编程技术 - 正文

深入理解JavaScript的React框架的原理(深入理解计算机系统)

编辑:rootadmin

推荐整理分享深入理解JavaScript的React框架的原理(深入理解计算机系统),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:深入理解新发展理念,推进供给侧结构性改革,深入理解计算机系统,深入理解新发展理念,推进供给侧结构性改革 心得体会,深入理解新发展理念,推进供给侧结构性改革,深入理解新发展理念,推进供给侧结构性改革,深入理解javascript特性.pdf,深入理解javascript特性.pdf,深入理解javascript,内容如对您有帮助,希望把文章链接给更多的朋友!

如果你在两个月前问我对React的看法,我很可能这样说:

我的模板在哪里&#;javascript中的HTML在做些什么疯狂的事情&#;JSX开起来非常奇怪!快向它开火,消灭它吧!

那是因为我没有理解它.

我发誓,React 无疑是在正确的轨道上, 请听我道来.

Good old MVC

在一个交互式应用程序一切罪恶的根源是管理状态。 “传统”的方式是MVC架构,或者一些变体。

MVC提出你的模型是检验真理的唯一来源 - 所有的状态住在那里。视图是源自模型,并且必须保持同步。当模式的转变,所以没有查看。

最后,用户交互是由控制器,它更新模型抓获。到目前为止,一切都很好。

模型发生变化时就要对视图进行渲染

这看起来相当简单。首先,我们需要描述视图——它是如何将模型状态转换到DOM上去的。然后,用户一发生了什么操作我们就要对模型进行更新,并且要对整个页面进行重新渲染... 对不&#; 没这么快哦. 不幸的事,这其实并没有这么直接,因为如下两个原因:

DOM实际上有某种状态,就比如一个文本输入框中的内容. 如果你完全作废你的DOM来进行重新渲染,这样的内容会丢失掉. DOM 操作 (像删除和插入节点) 真的慢. 频繁的渲染会导致严重的性能问题.

那么我们如果在避免这些问题的前提下保持模型和视图同步呢&#;数据绑定

过去三年,被引进用来解决这个问题最常用多框架功能就是数据绑定.

数据绑定能自动地保持模型和视图的同步. 通常在JavaScript中就代表了对象和DOM.

它会通过让你声明应用中各个块之间的依赖来对这一同步进行打包。状态的变化会在整个应用程序中蔓延,然后所有的依赖块都会被自动更新.

让我们来看看一些有名的框架中它实际是如何运作的吧.

Knockout

Knockout 主张使用的是 MVVM (模型-视图-视图模型) 方法,并且帮你实现了“视图”的部分:

而这就是了. 不管改变那边的输入值都在让span中发生变化。你从来都不需要写代码将其进行绑定。这多酷啊,呵&#;

但是等等,模型不是真相的来源么&#; 这里的视图模型从来获得它的状态呢&#; 它是怎么知道模型发生了变化的呢&#; 有趣的问题啊.

Angular

Angular 采用保持模型和视图同步的方式描述了数据绑定. 文档时这么描述的:

但是... 视图应该直接通模型打交道么&#; 这样它们不久紧紧的耦合起来了么&#;

不管怎么样,我们还是来义务地看看hello world示例吧:

从这个示例中,看起来像是控制器有了状态,并且有类似模型的行为 - 或者也许是一个视图模型&#; 假设模型在其它的地方, 那它是如何保持与控制器的同步的呢&#;

我的头开始有点儿疼了.数据绑定的问题

数据绑定在小的例子中运行起来很不错。不过,随着你的应用规模变大,你可能会遇到下面这些问题.

声明的依赖会很快引入循环

最经常要处理的问题就是对付状态中变化的副作用。这张图来自 Flux 介绍,它解释了依赖是如何开始挖坑的:

深入理解JavaScript的React框架的原理(深入理解计算机系统)

你能预计到当一个模型发生变化时跟着会发生什么改变么&#; 当依赖发生变化时,对于可以任意次序执行的代码你很难推理出问题的起因。模板和展示逻辑被人为的分离

视图扮演了什么角色呢&#; 它扮演的就是向用户展示数据的角色。视图模型扮演的角色又是什么呢&#; 它扮演的也是向用户展示数据的角色?有啥不同?完全没有!

毫无疑问,模板割裂了计数 ~ Pete Hunt

最后,视图组件应该能操作其数据并以需要的格式对数据进行展示。然后,所有的模板语言本质上都是有缺陷的:它们从来都不能达到跟代码一样的表现力和功能。

很简单, {{# each}}, ng-repeat 和 databind="foreach" 这些都是针对 JavaScript 中某些原生和琐碎事务的拙劣替代物。而它们不会更进一步走得更远。因此它们不会为你提供过滤器或者映射。

数据绑定是应重新渲染而生的小技巧

什么是圣杯不再我们的讨论之列。每个人总是想要得到的是,当状态发生变化时能重新对整个应用进行渲染。这样,我们就不用去处理所有麻烦问题的根源了:状态总是会随着时间发生变化——给定任何特定的状态,我们就可以简单的描述出应用回是什么样子的。

好了,问题清楚了。哥们,我希望某些大公司能组个超能天才开发者团来真正解决这个问题...拥抱Facebook的React

事实证明他们做到了。React实现了一个虚拟的DOM,一种给我们带来的圣杯的利器.虚拟的DOM是啥东西呢&#;

很高兴你能这么问?让我们来看看一个简单React示例.

这就是一个React组件的所有API。你必须要有一个渲染方法。复杂吧,呵呵&#;

OK, 但是 <div> 是什么意思&#; 那不是 JavaScript 啊! 对了,它就不是.

你的新伙伴,JSX

这段代码实际上是用 JSX 写的,它是 JavaScript 的一个超集,包含了用于定义组件的语法。上面的代码会被编译成 JavaScript,因此实际上会变成:

你明白这段对 createElement 调用的代码么&#; 这些对象组成了虚拟 DOM 的实现。

很简单 : React 首先在内存中对应用的整个结构进行了组装。然后它会把这个结构装换成实际的 DOM 节点并将其插入浏览器的 DOM 中。

OK,但是用这些奇怪的 createElement 函数编写 HTML 的目的是什么呢? 虚拟的DOM就是快

我们已经讨论过, 操作 DOM 消耗大得离谱,因此它必须以尽可能少的时间完成。

React 的虚拟 DOM 使得两棵 DOM 结构的比对真正快起来,并且能确切的找到它们之间有什么变化. 如此,React 就能计算出更新 DOM 所需要做出的最小变更。

实话说,React 能比对两棵 DOM 树,找出它所要执行的最小操作集。这有两个意义:

如果一个带有文本的输入框被重新渲染,React 会知道它有的内容, 它不会碰那个碰那个输入框。不会有状态发生丢失的! 比对虚拟 DOM 开销一点也不昂贵,因此我们想怎么比对都可以。当其准备好要对 DOM 进行实际的修改时,它只会进行最少量的操作。没有额外的拖慢布局之虞!

那我们还要在状态发生变化时记住这两个对整个 app 进行重新渲染的问题么&#;

这都是过去式了。

React 将状态映射到 DOM

React 中只有虚拟 DOM 的渲染和比对是神奇的部分。其优秀性能是使得我们拥有简化了许多的整理架构的基础。有多简单呢&#;

React 组件都是幂等(一个幂等操作的特点是其任意多次执行所产生的影响均与一次执行的影响相同)的函数。它们能在任意一个实时的点来描述你的UI。~ Pete Hunt, React: 对最佳实践的重新思考

简单的幂等函数。

React 组件整个就是这么一个东西,真的。它将当前的应用状态映射到了 DOM。并且你也拥有JavaScript的全部能力去描述你的 UI——循环,函数,作用域,组合,模块 - 不是一个蹩脚的模板语言哦.

今天就开始使用 React

React 一开始会有点令人生畏。它提出了一个实在是太大了点的模式转变,这总有点令人不舒服。不过,当你开始使用它时其优势会变得清楚起来。

React 文档很优秀. 你应该照着教程对其进行一下尝试。我确信如果你给它一个机会,你肯定会爱上她。

编码快乐!

由ReactJS的Hello world说开来 这篇文章提供了代码实例和在React.js(一个Facebook工程师开发的被用于构建用户界面的Javascript库)中高水平的概念.这些概念会被详细的发表在下面的文

简介JavaScript中Math.cos()余弦方法的使用 这个方法返回一个数字的余弦值。该余弦方法返回-1和1之间的数值,它表示角度的余弦值。语法Math.cos(x);下面是参数的详细信息:x:一个数字.返回值:返

JavaScript中使用指数方法Math.exp()的简介 此方法返回Ex,其中x是参数,E是欧拉不变,自然对数的底数。语法Math.exp(x);下面是参数的详细信息:x:一个数字.返回值:返回变量x的指数值例子:htmlheadti

标签: 深入理解计算机系统

本文链接地址:https://www.jiuchutong.com/biancheng/379078.html 转载请保留说明!

上一篇:超级给力的JavaScript的React框架入门教程(超级给力的好人有哪些)

下一篇:由ReactJS的Hello world说开来(react.development.js)

  • 免抵退税退的是什么税
  • 经营许可证要交税吗
  • 简易征收增值税怎么做账
  • 一般纳税人销售使用过的固定资产
  • 叉车需要购置税吗
  • 增值税预缴税金交错了怎么办
  • 转增股如何计算资本公积金?
  • 用党费返还款购置资产应如何账务处理?
  • 减少实收资本会引起资产和所有者权益发生变化吗
  • 转租的门面怎么办营业执照
  • 总公司委托分公司开票的委托书
  • 投资款怎样缴印花税?
  • 增值税专用发票抵扣期限
  • 预收账款与预付账款均属于负债
  • 属于资金的筹资方式是
  • 发票纳税人识别号在哪里看
  • 营业外收入征企业所得税吗
  • 体育用品怎么才能买到
  • 食堂伙食费需要开票吗
  • 其它综合收益算利润吗
  • 冲账与挂账之间有什么区别?
  • 合伙企业收到投资款要缴纳印花税吗
  • 成本核算的基本方法及适用范围
  • 机器用油怎么做成的
  • win10用户头像错误 设置用户头像失败,请再试一次
  • 苹果手机系统更新在哪里找
  • 开了红字发票销售方应怎么账务处理?
  • windows11怎么查看显卡
  • 期初银行余额有误怎么调分录怎么写
  • PHP:oci_password_change()的用法_Oracle函数
  • 耕地占用费与耕地的区别
  • 公允价值变动损益借贷方向增减
  • 会计中持有至到期投资是什么意思
  • 进项税不得抵扣的意思
  • 资产负债表中其他流动资产包括哪些科目
  • php环境搭建教程
  • php504错误
  • 补缴税款后还能退税吗
  • php单链表使用场景
  • 看了这篇文章感触很深的说说
  • 社保在会计上的分类
  • 公司与公司往来账表格怎么制作
  • 建筑业总包增值税
  • 维修费应该计入什么科目
  • 个体经营所得可以用投资人申报吗
  • 材料暂估入库的依据有哪些
  • 自定义函数是啥
  • 个人所得税专项附加扣除赡养老人
  • 存货成本费用
  • 差旅费报销金额大于实际发生金额
  • mysql批量新增字段
  • 房地产按揭贷款政策
  • 经营费用是指
  • 合作建房土地增值税清算案例
  • 增值税普通发票和电子普通发票的区别
  • 房租退回进项税额转出会计分录
  • 固定资产折旧的影响因素
  • 盈余公积根据什么确定
  • 公益救济性捐赠应计入的会计科目是
  • 水电费收据可以写一张上吗
  • 新手学会计怎么学
  • linux 的ll
  • 如何编译安装
  • unix怎么切换用户
  • win8默认输入法设置
  • 64位ubuntu8.04 安装QQ
  • fsm32.exe是什么进程 有什么作用 fsm32进程查询
  • lnmp php
  • cocos2dx开发的游戏
  • nodejs中的模块以及作用
  • Express作者TJ告别Node.js奔向Go
  • jquery 插件写法
  • android内存机制
  • unity获取手机型号
  • JavaScript中Number.MAX_VALUE属性的使用方法
  • unity 5.4
  • 知道金额和税额怎么求
  • 纳税人虚假纳税申报
  • 现在还有地方税务登记证吗
  • 甘肃省国家税务局电子税务局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设