React版本更新及升级须知(持续更新)
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; text-align: center; font: 18.0px "PingFang SC Semibold"; color: #000000 }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "PingFang SC"; color: #000000 }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "Helvetica Neue"; color: #000000; min-height: 12.0px }
p.p4 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px "Helvetica Neue"; color: #000000 }
p.p5 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "Helvetica Neue"; color: #000000 }
p.p6 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "PingFang SC Semibold"; color: #000000 }
p.p7 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "PingFang SC Semibold"; color: #ee220c }
p.p8 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "Helvetica Neue"; color: #000000; min-height: 13.0px }
p.p9 { margin: 0.0px 0.0px 0.0px 0.0px; text-align: right; font: 11.0px "PingFang SC Semibold"; color: #000000 }
p.p10 { margin: 0.0px 0.0px 0.0px 0.0px; text-align: right; font: 11.0px "Helvetica Neue"; color: #000000 }
span.s1 { font: 18.0px "Helvetica Neue" }
span.s2 { font: 18.0px "PingFang SC" }
span.s3 { font: 11.0px "Helvetica Neue" }
span.s4 { }
span.s5 { font: 14.0px "PingFang SC" }
span.s6 { font: 11.0px "PingFang SC" }
span.s7 { font: 11.0px "Helvetica Neue"; text-decoration: underline }
span.s8 { font: 11.0px "PingFang SC"; color: #000000 }
以下内容参考React官方blog(https://reactjs.org/blog/all.html),进行了一些总结。从当前项目React版本号V0.14.8开始往后,并未列出所有的React版本更新内容是因为某些更新迭代只是一些细小的bug修复或者是完善,对于我们目前的开发并未有太大影响,所以跳过。
React V15.0(不再支持IE8)
1,去除data-reactid属性
组件mounting时,React内部采用document.createElement来替代innerHTML,之前版本的React是生成一堆HTML字符串,再设置node.innerHTML。当时是因为在那时候所有支持react的浏览器中,innerHTML要比createElement速度要快,设置data-reactid也是为了便于react追踪虚拟DOM节点,配合innerHTML,但是带来的缺陷就是每次在render的时候,需要给每一个虚拟DOM节点重新绑定这个属性,实际上是很消耗性能的。但是之后随着浏览器的优化,情况不再如此,使用createElement之后,React速度更快,因此不再需要data-reactid这个属性,每一个节点都是通过React.createElement这个方法创建出来,所以对所有的节点都有控制权,在渲染时可以构建出直接映射,因此不需要通过绑定reactid来追踪节点。这是v15版本的最大亮点。
2,去除文本节点的多余span标签
之前版本对于文本节点的渲染,react默认会在文本节点外面添加一层span标签,比如
<div>hello {this.props.name}</div>,该节点渲染成功时会看到内部出现了两个span标签,如果我们在节点内部本身就添加了span标签,对应的css样式里也有用span标签来区分关键字样式,那这样在渲染时容易导致冲突,而且本身就没有必要给不需要的节点添加不必要的标签。因此,React15版本去掉了额外的span标签。
3,全面支持SVG标签
支持所有由浏览器实现的SVG标签及属性。
4,关于null的render,用注释节点来表示
通过<noscript>标签来表示null,在react多应用中带来的性能提升。
5,功能性组件允许return一个null
之前无论是无状态组件或者是一个纯函数,都不允许返回一个null,但是15版本允许返回null了。
其他可能会涉及到的小的注意点:
React.cloneElement(),修复了如果传入未定义的props会返回未定义的元素,现在会有默认的defaultProps;
之前0.14版本已经弃用的方法全部删除,如果引用会报错;
允许data-名称以数字开头的属性等。
版本升级注意:总体来说,代码无需改动,不会影响编译,性能会有所提升,但是从15版本开始,React DOM不再支持IE8,解决方案找到两个:
1,es5-shim和es5-sham;
2,https://github.com/NervJS/nerv(可兼容到ie7)
React V15.4.0
1,分离React和React DOM
React包目前只包含和React渲染无关的如React.Component和React.createElement()等内容,render则放到了react-dom包中。
2,新增React Perf
ReactPerf启动后,可以在Chrome时间轴中查看在组件中花费的时间,包括组件的挂载,更新和卸载
版本升级注意:React V0.14中如果使用ReactDOM.render()方法的需要改变,并且render已被分离到react-dom包中,引入时需要注意,其他并无大碍。
React V15.5.0
1,React.PropTypes迁移
在开发过程中,常常会用到Prop的type验证,React V15.4和之前都是直接从主React对象上访问,但是从15.5版本开始,需要引入prop-types包并从包里导入。
2,React.createClass不再推荐使用
从15.5.0版本开始,React.createClass推荐改为引入create-react-class包,因为ES2015以前并未将类作为语言的一部分,所以暂时使用了React自身提供的React.createClass,然而随着ES2015关于类的引入,JavaScript类现在是在React组件中创建组件的首选方式。
其他可能会涉及到的小的注意点:
React.PureComponent来代替react-addons-pure-render-mixin和react-addons-shallow-compare,这两个包之前在性能优化方面会用到。
版本升级注意:React.createClass已不再推荐使用,但这时候如果还是用的该方法,也不会报错,但是后续新版本会出错,这个后面会提到;还有就是PropTypes的引入,这个需要改动,其他无影响。
React V15.6.0
style属性中添加对css变量的支持。
React V15.6.2
CSS列不再附加px后缀。
React V16.0
1,render函数下的return类型新增:fragments 和 strings
之前版本每次render后的return都必须用一个div包裹住或者是一个自定义组件,现在不再需要包在一个里面,而是可以直接返回一个数组(数组还是需要添加key属性,便于diff算法),或者是一个字符串。
2,错误处理的改变
之前在渲染过程中如果运行出现错误,会导致React直接奔溃,甚至会展示出一些错误信息在界面上,React 16的错误机制是一旦渲染过程中或者生命周期中出现错误,整个组件树会从根目录下卸载,防止显示损坏的数据。
3,更好的服务器端渲染
服务端渲染是15版本的3倍,配合8.4版本的Node,大概有3.8倍
4,支持自定义的DOM属性
之前版本会直接忽视掉无法识别的HTML属性,而现在会直接传递给DOM,减少文件大小。
5,减小文件大小
react包:从20.7kb(6.9kb gzipped)降低到5.3kb(gkbip 2.2kb)
react-dom包:从141kb(42.9kb gzipped)降低到103.7kb(32.6kb gzipped)
react+react-dom包:从161.7kb(49.8kb gzipped)降低到109.7kb(34.8kb gzipped)
与之前版本相比,相当于缩小了32%(gzip的30%)
6,componentDidCatch的推出
可以在子组件树种的任何位置捕获js错误,并且记录错误,并且显示备用UI而不是崩溃的组件树,这个相比于从根组件全部卸载的错误处理要更优。
其他可能会涉及到的小的注意点:
setState在render的过程中会导致更新,所以绝对不能在渲染过程中使用setState,以前使用可能不会出错,现在应该会造成栈溢出;
componentDidUpdate不再接收prevContext参数;
React 16依赖于Map类型和Set类型,如果需要支持旧版的浏览器,需要单独引入这两个,可以借助core-js或者babel-polyfill这两个库,用法如下:
版本升级注意:从15版本升级到16版本,原有的写法不会有问题,但是需要引入map和set语法来支持旧版浏览器,其他就是一些新写法的更新,可以调整代码进行优化,如果不调整也不会有问题。
React V16.2
1,Fragments的升级
Fragments在上个版本已经支持,但是并未有大的改进,在此版本中,Fragments的升级是一大亮点。先看一段HTML:
在16.0版本以前,如果我们要在React中render,唯一的方法是将他们包裹在一个div中,而React V16.0开始支持返回数组形式,则可以写成以下方式:
需要注意的是,数组中必须以逗号分隔,必须带key属性,字符串必须用引号括起来。
但是上面这种写法体验不是很好,所以16.2版本推出了Fragment组件(React.Fragment):
当然,也可以用Fragment来包裹其他自定义组件。还有一种写法是用JSX片段语法<></>,但是这种写法是不支持任何属性的,包括key属性,而Fragment目前唯一支持的属性就是key:
其他可能会涉及到的小的注意点:
如果配合eslint,上面这种JSX Fragments写法需要eslint版本升级到3.x,babel-eslint升级到7,在.eslintrc文件中确保添加了 “parser”: “babel-eslint”;
版本升级注意:16.2仅仅是在16.0基础上新增了对Fragment的提升,其它没有大改动。
总结:React从目前版本V0.14.8更新至最新版本V16.2.0,会经历两次较大的版本更新,一个是15.0,一个是16.0。
较大的优化是:性能的提升,渲染速度的提升,对异常的处理更优,以及包的大小减小,
带来的影响是:IE8的不支持(目前有解决方案),部分写法的废弃,部分引入包的更改。
React版本更新及升级须知(持续更新)的更多相关文章
- react+typescript报错集锦<持续更新>
typescript报错集锦 错误:Import sources within a group must be alphabetized.tslint(ordered-imports) 原因:impo ...
- React Native汇错归纳(持续更新中……)
1.2017-10-25: 报错信息:“Cannot find entry file index.android.js in any of roots…..” 解决方法: 1.首先从虚拟机中找问题:看 ...
- React Native之坑总结(持续更新)
React Native之坑总结(持续更新) Genymotion安装与启动 之前我用的是蓝叠(BlueStack)模拟器,跑RN程序也遇到了一些问题,都通过搜索引擎解决了,不过没有记录. 但是Blu ...
- 私人网盘系统2.0—全部升级为layUI+PHP(持续更新中)shang
网盘系统2.0 上周,我做了第一版的“私人网盘系统”,http://www.cnblogs.com/sunlizheng/p/7822036.html 没看过的朋友可以去看一下,这周在家升级做了第 ...
- ReactNative开发笔记(持续更新...)
本文均为RN开发过程中遇到的问题.坑点的分析及解决方案,各问题点之间无关联,希望能帮助读者少走弯路,持续更新中... (2019年3月29日更新) 原文链接:http://www.kovli.com/ ...
- 技能get,React的优雅升级!
今日,我们不啖鸡汤,不饮鸡血 只有干货——关于React的优雅升级 双手奉上,来,干了! -2019年第4期- 夫 子 说 本次升级基础包情况:react 15.6 -> 16.6 升级流程: ...
- [转帖]linux常用命令大全(linux基础命令入门到精通+实例讲解+持续更新+命令备忘录+面试复习)
linux常用命令大全(linux基础命令入门到精通+实例讲解+持续更新+命令备忘录+面试复习) https://www.cnblogs.com/caozy/p/9261224.html 总结的挺好的 ...
- 4W字的后端面试知识点总结(持续更新)
点赞再看,养成习惯,微信搜索[三太子敖丙]关注这个互联网苟且偷生的工具人. 本文 GitHub https://github.com/JavaFamily 已收录,有一线大厂面试完整考点.资料以及我的 ...
- vue-qiankun公司微前端项稳定目落地后的总结(附github仓库demo,将会持续更新)
️本文为博客园社区首发文章,未获授权禁止转载 大家好,我是aehyok,一个住在深圳城市的佛系码农♀️,如果你喜欢我的文章,可以通过点赞帮我聚集灵力️. 个人github仓库地址: https:gi ...
随机推荐
- MssqlOnLinux 备份和日志【3】
数据库恢复模式: 一 简单模式:只对数据进行备份,不备份日志. 二 完整模式:支持数据,日志备份. 三 大容量日志模式:支持数据,日志备份.适用于大规模大容量操作,用最小的方式记录大多数操作. 数据库 ...
- 扩充表字段长度,引发的意外KILLED/ROLLBACK
这一段时间,因为系统升级,新系统产生的数据长度,比原来的数据长度要长,所以说要扩充一下字段长度. ) --修改字段长度sql 在执行的时候,有这样一个情况. 例如Student表的Name字段长度是n ...
- PE文件简介
PE文件的全称是Portable Executable,意为可移植的可执行的文件,常见的EXE.DLL.OCX.SYS.COM都是PE文件,PE文件是微软Windows操作系统上的程序文件(可能是间接 ...
- linux下centos6.8相关配置,以及音频相关配置
一:安装上传下载命令 1:cd /tmp 2:wget http://www.ohse.de/uwe/releases/lrzsz-0.12.20.tar.gz 3:tar zxvf lrzsz-0. ...
- 日期插件-flatpickr
github的仓库地址:https://github.com/chmln/flatpickr 手册地址:http://www.htmleaf.com/Demo/201608213895.html ...
- \(?0\d{2}[) -]?\d{8}正则表达式的解释
正则表达式30分钟出现了这样一个正则表达式:(?0\d{2}[) -]?\d{8} "("和")"也是元字符,所以需要转义. ?匹配零或一次 (? 表示 出现( ...
- 第一次写博客,就写如何向外行介绍自己做的是什么,那个我是做web的
如果想外行问你是做什么的,改如何回答.和内行说java后台就可以了,但外行听不懂,我们该如何描述呢? 我的方法是:我做的是java web开发,不是内外的外,是个英文单词web,全名叫world wi ...
- ThinkPHP3.2中英文切换!
小伙伴们好久不见!!! 最近公司项目版本升级,小梦已经忙成了狗,无暇顾及文章,今天抽时间写一篇助助兴! 用Thinkphp这个国产框架已经2年多了,现在有一个小功能:网站中英文切换功能,当然这 ...
- ajax中url赋json格式的值时发生中文乱码的相关问题
具体流程:转入到jsp界面时会加载ajax,ajax转到url时传带hide在jsp界面的值titleString,其来源见下面的代码. String title=new String("\ ...
- (转)Android Studio Error:Failed to resolve: com.android.support:appcompat-v7:25.1.0解决方案
今天不知道为什么导入eclipse项目后就出现了错误,没导入之前是正常使用AS的 Error:(26, 13) Failed to resolve: com.android.support:appco ...