React v16.0正式版发布

原文:https://deploy-preview-10824--reactjs.netlify.com/blog/2017/09/26/react-v16.0.html
译者:miaoyu

我们很高兴的宣布React v16.0发布了,这次版本的新增了一些呼声很高的特性,包括支持render返回数组和字符串错误处理portals自定义DOM属性优化服务器端渲染以及减少文件大小

支持render返回数组和字符串

你现在可以通过render方法返回一个包含元素的数组:

render() {
  // 不再需要在外边包裹一个额外的元素!
  return [
    // 不要忘记加key哦 :)
    <li key="A"/>First item</li>,
    <li key="B"/>Second item</li>,
    <li key="C"/>Third item</li>,
  ];
}

同时也支持返回字符串。

API 文档

更好的错误处理

在此之前,React在渲染时运行错误会导致渲染中断,接着抛出一个令人匪夷所思的错误以及要求刷新页面来恢复。为了解决这个问题,React16 使用了更有弹性的错误处理策略。如果在组件的render方法或者生命周期方法中抛出错误,整个组件会被卸载。这样可以阻止显示错误的页面。然而这可能不是理想的用户体验。

每当错误发生时,你可以使用错误边界而不是卸载整个应用。错误边界是一个特殊的组件,捕捉组件树的错误然后显示降级的UI来提升体验。其实错误边界就像try-catch语句,只不过是用于React。

想获得更详细的信息, 查看我们之前的文章.

Portals

Portals提供一个方法来渲染DOM层级之外的DOM节点。

render() {
  // React不需要创建一个新的div。将被渲染到`divNode`中。
  // `divNode` 是一个在DOM中任何地方都有效的节点。
  return React.createPortal(
    this.props.children,
    divNode,
  );
}

查看完整portals示例

更好的服务器端渲染

不再要求初始渲染和服务器的结果完全匹配,取而代之的是尝试重用更多已存在的节点。减少校验!

服务器端渲染的特性被完全重写以支持数据流。React核心团队成员Sasha Aicken(主要负责这个特性),他写了一篇很牛逼的文章来描述React16服务器端渲染的提升:“对流的渲染可以节省时间,在document后面部分生成之前就可以把document前面部分发送给浏览器。所有主流的浏览器,都会在当服务器传输流时,开始解析和渲染document。”

支持自定义DOM属性

React将不再忽略未被识别的HTML和SVG属性,React会将它们传递给DOM。这样还带来一个好处就是允许我们把它们从React属性的白名单剔除出去,从而减小了文件大小。

缩小React的体积

尽管内容有所增加,但React 16的实际大小比起15.6.1小得多!

  • react 文件大小从20.7kb(压缩文件6.9kb)缩小到5.3kb(压缩文件2.2kb)。

  • react-dom 文件大小从141kb(压缩文件42.9kb)缩小到103.7kb(压缩文件32.6kb)。

  • react + react-dom 文件大小从161.7kb(压缩文件49.8kb)缩小到109kb(压缩文件34.8kb)。

与前一个版本相比,大小减少了32%(压缩后大小减少了30%)。

体积的缩小主要是因为打包方式的改变。React使用Rollup 来为不同的目标格式创建bundles,带来的结果不仅仅是体积减小也使得运行时性能得到提升。

全新架构

React16是在新架构之上第一个版本,代号“Fiber”。

这次发布的大部分特性,比如错误边界和fragments,都是重写核心代码实现的。在接下来的几个版本中,你可以期待更多的特性,因为React的无限潜能已经被激发出来了。

我们正在开发异步渲染———一种浏览器定期协同渲染策略,异步渲染会使应用响应更稳定,因为React不会阻塞主线程。

我们认为异步渲染是一个很好的解决方案,它也代表了React未来的方向。这个特性会尽可能平顺的迁移到v16.0,目前我们还没有启用任何异步特性,但是我们很高兴会在接下来几个月推出这一解决方案,请持续关注!

升级

尽管React16包含了很重大内部改变,但在升级方面,和之前发布React版本一样。在一般情况下,如果你的应用运行在15.6上没有任何警告提示,那就可以运行在16上。

注意

如果你在服务器端渲染HTML,请使用ReactDOM.hydrate替换ReactDOM.render。如果你只是在客户端渲染,那么请继续使用ReactDOM.render。

重大改变

  • unstable_handleError方法改名为componentDidCatch,你可以用codemod自动迁移到新的API。

  • 如果在生命周期中调用ReactDOM.renderReactDOM.unstable_renderIntoContainer这两个方法会返回null,如果真有这种需求,可以使用portals或者refs。

  • setState:

    • 调用setState传入null将不会触发更新。

    • 直接在render方法中调用setState会导致更新。不管怎样,你也不应该在render方法中调用setState

    • setState的回调函数(第二个参数),在componentDidMountcomponentDidUpdate方法执行后立即调用。

  • 当用<B />替换<A />,B组件的componentWillMount会在A组件的componentWillUnmount之前执行。

  • 在此之前,改变组件的ref,总会在调用改组件render方法之前分离ref,现在是让它在 DOM 变更后再做改变。

  • 通过非React方式修改组件后重新渲染是很不安全的,虽然在之前的版本中可行,但是现在我们会抛出警告,除非你使用ReactDOM.unmountComponentAtNode来清除你的组件树。查看示例

  • componentDidUpdate生命周期不会再返回prevContext 参数。(查看 #8631)

  • 浅渲染不在调用componentDidUpdate(),因为DOM的refs是不可用的。这也使得它和componentDidMount()保持一致(componentDidMount()在之前的版本也是不会调用的)。

  • 浅渲染不再执行unstable_batchedUpdates()

打包

  • 不再有react/lib/*react-dom/lib/*两个路径。即使是在CommonJS环境中,React和ReactDOM预编译成一个单独的文件。如果你之前依赖React内部文件,并且不再工作了,那么请告诉我们你的具体情况,我们会尝试为你制定迁移策略。

  • 不再有react-with-addons.js编译版本,所有兼容的插件都会在npm上单独发布,如果你需要的话有单个文件应用于浏览器的版本。

  • React.createClass 现在等同于 create-react-classReact.PropTypes 等同于 prop-types, React.DOM 等同于 react-dom-factories, react-addons-test-utils 等同于 react-dom/test-utils, 以及浅渲染等同于 react-test-renderer/shallow,请参阅 15.5.015.6.0 的文章 来迁移代码。

  • 应用于浏览器的单个文件的文件名和路径被修改了,目的是为了区分开发模式和生产模式,比如:

    • react/dist/react.jsreact/umd/react.development.js

    • react/dist/react.min.jsreact/umd/react.production.min.js

    • react-dom/dist/react-dom.jsreact-dom/umd/react-dom.development.js

    • react-dom/dist/react-dom.min.js → react-dom/umd/react-dom.production.min.js

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容