react是什么

react是开发出来用来促进UI交互的,创建带有状态的、可复用的UI组件的IU库

react不仅可以在浏览器端使用,还可以在服务器端使用,还可以两端一起使用。

react的底层概念:运用的是virtual DOM(虚拟DOM),然后根据UI组件的状态变化,有选择的渲染DOM的节点树,尽可能的操作最少的DOM来更新组件。

虚拟DOM是怎么工作的

1.在Web开发中,需要将数据的变化实时反映到UI上,就需要对DOM进行操作,但是复杂频繁的DOM操作会产生性能瓶颈。所以DOM就引入了虚拟DOM的机制。

实际上,在React中,render方法得到的实际上不是真实的DOM节点,而仅仅是轻量级的JavaScript对象,我们称之为虚拟DOM.

2.虚拟DOM是React的一大亮点,具有批处理(batching)和高效的Diff算法。无需担心性能问题而毫无顾忌的随时刷新整个页面,由虚拟DOM来确保只对界面上真正变化的部分进行实际的DOM操作。

了解React虚拟DOM的机制就可以更好的理解React组件的生命周期,而且对于进一步优化React组件的生命周期。

如果没有虚拟DOM,就相当于重置innerHTML,在数据变动比较大的情况下,比较合理,但是如果只有一小部分数据变化时,也要重置整个innerHTML,这就造成了很大的浪费。

两者的比较

innerHTML: render html string + 重新创建所有的DOM元素

virtual DOM: render Virtual DOM + diff + 必要的DOM更新。

3.和DOM操作比起来,js计算还是非常便宜的。Virtual DOM + diff 显然要比render string慢,但是后面的DOM操作就比较便宜了。

DOM完全不属于JavaScript,也不在JavaScript引擎中,JavaScript实际上是一个独立的引擎,而DOM其实是浏览器引出的一组让JavaScript操作HTML文档的API而已,在即时编译的时代下,调用DOM的开销是很大的,而Virtual DOM的执行完全都在JavaScript引擎中,不存在这个开销。

4.React.js相对于直接操作原生DOM有很大的性能优势,很大程度上归功于虚拟DOM的batching和diff,batching把所有的DOM操作搜集起来,一次性提交给真实的DOM,

什么是虚拟DOM

React中,将真实的DOM抽象成一个JavaScript对象,也就是虚拟DOM,比如构造一个虚拟的DOM.

var element = {
element: 'ul',
props: {
id: 'list'
},
children: [
{element:'li',props:'li1',children:['这是第一个li']},
{element:'li',props:'li2',children:['这是第二个li']}
]
} //element.js
function Element(tagName,props,children){
this.tagName = tagName;
this.props = props;
this.children = children;
} module.exports = function(tagName,props,children){
return new Element(tagName,props,children)
} var el = require('./element');
var ul = el('ul',{id:'ulist'},[
el('li',{id:'list1'},['1list']),
el('li',{id:'list2'},['list2'])
])
//ul只是一个JavaScript对象表示的DOM结构,页面上并没有这个结构,可以根据这个ul构建真正的<ul>
Element.prototype.render = function(){
var d = document.createElement(tagName);
//获取props
var props = this.props;
for (key in props) {
var propValue = props[key];
d.setAttribute(key,propValue);
} //获取children
var children = this.children || [];
children.forEach(function(child){
// if (child instanceof Element){
// tnode = child.render();
// }
// else{
// tnode = document.createTextNode(child);
// }
var childEl = (child instanceof Element) ? child.render():document.createTextNode(child)
d.appendChild(childEl);
})
return d;
} var ulRoot = ul.render();
document.body.appendChild(ulRoot);
//ulRoot是真正的DOM节点,把它塞入文档中,这样body里面就有了真正的<ul>的DOM结构。

在React中,也有一个render函数,当React中有state转移的过程,所以每次state有变化之后,就会触发render函数,重新构造一个虚拟DOM树,对比新旧DOM树的差别,记录下差别,然后只针对差异部分对应的真实DOM进行操作。先总结到这里,下一篇博客,详细讲解Diff算法。

React的思想的更多相关文章

  1. React 设计思想

    https://github.com/react-guide/react-basic React 设计思想 译者序:本文是 React 核心开发者.有 React API 终结者之称的 Sebasti ...

  2. [转] React同构思想

    React比较吸引我的地方在于其客户端-服务端同构特性,服务端-客户端可复用组件,本文来简单介绍下这一架构思想. 出于篇幅原因,本文不会介绍React基础,所以,如果你还不清楚React的state/ ...

  3. React设计思想

    熟悉一个新技术的关键是熟悉他的特色和理念 React框架本身和我们常用的JavaScript MVC框架,如:AngularJS,Backbone,Ember等,没有直接的可比性.在React的官方博 ...

  4. React 同构思想

    作者:yangchunwen React比较吸引我的地方在于其客户端-服务端同构特性,服务端-客户端可复用组件,本文来简单介绍下这一架构思想. 出于篇幅原因,本文不会介绍React基础,所以,如果你还 ...

  5. 浅谈React编程思想

    React是Facebook推出的面向视图层开发的一个框架,用于解决大型应用,包括如何很好地管理DOM结构,是构建大型,快速Web app的首选方式. React使用JavaScript来构建用户界面 ...

  6. React 编程思想翻译及学习笔记

    第一步:把UI图按组件层次结构拆分开 FilterableProductTable (橙色): 包含整个例子 SearchBar (蓝色): 接收所有用户输入 ProductTable (绿色): 基 ...

  7. React 核心思想之声明式渲染

    React 发展很快,概念也多,本文目的在于帮助初学者理清 React 核心概念. React 及 React 生态 React 的核心概念只有 2 点: 声明式渲染(Declarative) 基于组 ...

  8. [译]Thinking in React

    编者按 使用React的思想来构建应用对我在实际项目中以及帮助他人解决实际问题时起到了很大作用,所以我翻译此文来向那些正在或即将陷入React或React-Native深坑的同胞们表示慰问.网上已经有 ...

  9. 【原】react中如何使用jquery插件

    react的思想是虚拟dom,提倡最好较少dom的操作,可是我们在写网页的时候,有些复杂的交互还是离不开jquery插件的.而且当你把jquery直接拿来用的时候,你会发觉会报错,要么是找不到那个插件 ...

随机推荐

  1. Java常用开发思想与知识点小记(一)

    1.   子类在覆盖父类的方法时,不能抛出比父类更多的异常(儿子不能比父亲干更多的坏事),所以只能捕捉异常,通常在web层捕获异常,给用户一个友好提示. 2.Java内存模型与并发编程三个特性 htt ...

  2. perl 复制exe文件的简单方法

    use warnings; use strict; open EXE, "cmd.exe" or die "Can not open cmd.exe:$!\n" ...

  3. python中的Queue模块

    queue介绍 queue是python的标准库,俗称队列.可以直接import引用,在python2.x中,模块名为Queue.python3直接queue即可 在python中,多个线程之间的数据 ...

  4. HDU 6119 小小粉丝度度熊 双指针

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6119 题意:中文题面. 解法:先处理可能交叉的区间,然后容易发现满足双指针的特性. //HDU 611 ...

  5. 经典卷积网络模型 — VGGNet模型笔记

    一.简介 VGGNet是计算机视觉组(Visual Geometry Group)和Google DeepMind公司的研究员一起研究的深度卷积神经网络.VGGNet探索了卷积神经网络深度与性能之间的 ...

  6. Tomcat debug模式下特别慢但是run正常处理方法

    转载自:http://blog.csdn.net/builderwfy/article/details/50785749 到网上查资料发现这是由eclipse和tomcat交互时,在debug模式启动 ...

  7. LinkedList 源码分析

    LinkedList :双向链表结构, 内部存在frist节点 和 last节点.通过改变 首节点和 尾节点的引用来实现新增和修改 有一个内部类: //节点类,内部包括前节点和后节点,和数据项 // ...

  8. python基础(1)---python简介

    一.python简介 Python是著名的“龟叔”Guido van Rossum在1989年圣诞节期间,为了打发无聊的圣诞节而编写的一个编程语言.目前Python已经成为实际上除了中国最流行的开发语 ...

  9. 玩转树莓派 - 修改Raspbian软件源加快软件下载速度

    这是 meelo 原创的 玩转树莓派 系列文章 步骤1:登录到Raspbian的命令行界面 步骤2:修改Raspbian的软件源 软件源是Linux系统免费的应用程序安装仓库,很多的应用软件都会这收录 ...

  10. java入门概念梳理总结

    Java入门学习 简介 public class HelloWorld { public static void main(String []args) { System.out.println(&q ...