[译] React 16.3(.0-alpha) 新特性
- 原文地址:What’s new in React 16.3(.0-alpha)
- 原文作者:Bartosz Szczeciński
- 译文出自:掘金翻译计划
- 本文永久链接:github.com/xitu/gold-m…
- 译者:pot-code
- 校对者:ryouaki、goldeli
React 16.3(.0-alpha) 新特性
React 16.3-alpha 于不久前推至 npmjs,已经可以用在项目中了,你最关心哪些变化呢?
2018 年 2 月 5 日更新 —— 之前我误解了
createContext的一些行为,所以更新了这一节的内容,主要为了反映出工厂方法的一些行为。
全新的 context API
Context API 一直很神秘 —— 本来它是一个官方推出的、文档化的 API,但开发者们又提醒我们尽量不要用这个 API,因为这个 API 还没完全确定下来,以后可能会再作修改,而且文档尚不完备。不过,是时候让它发光发热了,RFC 流程已经通过了,新的 API 代码也已经合并了,用起来也更加顺手了。至少在状态管理这方面,如果项目并不复杂的话,完全可以不用 Redux 和 MobX。
新的 API 方法主要体现在 React.createContext() 上,调用之后会创建两个组件:
调用 React.createContext() 创建一个上下文(context)对象
这个工厂方法返回的对象包含“Provider”和“Consumer”两个属性,即上文提到的两个组件。
Provider 组件用来为其所有子层级组件提供数据,示例如下:
在上图中,将需要接受数据的组件放在 ThemeContext.Provider 下,设置其 value 属性,用来存放需要传递的数据。当然这个 value 也可以是动态变化的(用 this.setState)。
接下来设置 Consumer 组件:
如果你把 Consumer 组件放在了 Provider 组件的外部(不在它的下面),其值会默认使用调用 createContext 时传入的值。
PS:
- Consumer 组件只能获取到对应的 Context 里设置的数据,即使新创建了一个 Context,传入和已有的 Context 一样的参数,不属于这个 Context 的 Consumer 是获取不到它设置的数据的。所以,不妨把 Context 看成一个组件,相同用途的 Context 只创建一次,再根据需要作导入导出(export/import)。
- 新的写法采用的是”方法即子组件模式”(即 function as child pattern,有时也称作 render prop 模式),如果你对这种模式很陌生,可以参考这里。
- 新的 API 不用再通过
prop-types设置contextProps了。
Consumer 下的 context 参数对应了 Provider 组件里设置的 value 属性,修改 Provider 里设置的数据会导致对应的 Consumer 下的组件重新渲染。
新的生命周期方法
另一个促使其进入 alpha 阶段的 RFC 和某些生命周期方法的废除有关,同时也还会引进一个(译者注:其实还有另外三个方法 —— 要废除的生命周期方法前面加个“UNSAFE_”前缀构成的新方法)新的方法。
这些改变旨在引导开发者作出最佳实践(将被废除的这些生命周期方法颇具坑点,具体可以参考我写的另一篇文章),这也有益于适应将来全面开放的异步渲染模式(这也是 React 16 “Fiber” 的首要目标)。
即将被废除的方法如下:
componentWillMount—— 即将废除,使用componentDidMount作为替代componentWillUpdate—— 即将废除,使用componentDidUpdate作为替代componentWillReceiveProps—— 即将废除,使用新引进的方法static getDerivedStateFromProps
不要瞎慌,这些方法现在都可以正常使用,不影响,到 16.4 版本才会正式打上“已废除”的标记,真正移除可能要到 17.0 以后。
Dan 表示,“故事还长,大家别慌”,然而仍有群众表示恐慌。
如果你开启了 StrictMode 或是 AsyncMode,它只会提示你方法已经废除了,不想看到这些提示信息可以使用如下方法替代:
UNSAFE_componentWillMountUNSAFE_componentWillReceivePropsUNSAFE_componentWillUpdate
静态方法:getDerivedStateFromProps
既然 componentWillReceiveProps 要被废除了,那么,还有其他的方法能根据 prop 的改变更新 state 吗(不推荐使用这种开发模式)?这里就要用到新引进的那个静态方法了。
这里说的静态和其他语言的概念是一样的,它是存在于类自身的方法,不依赖实例的创建。与一般的类方法的区别在于它不能访问 this 关键字,还有就是方法前面有个 static 修饰符。
嗯,那行,但是有一个问题,既然访问不到 this 了,那还怎么用 this.setState 来更新状态呢?答案是,“压根就不需要用这个方法了”,你只需要返回新的状态就行了,直接 return 出去,不需要用方法去设置。如果不需要更新状态,返回 null 就行了:
此外,返回值的机制和使用 setState 的机制是类似的 —— 你只需要返回发生改变的那部分状态,其他的值会保留。
敲黑板:
说了这么多,还是要提醒下各位记得在构造器里初始化一下 state(在构造器里或者用 class field),不然就会报上面的错误。
这个方法在组件首次挂载和将要重新渲染的时候会调用,所以你可以在它里面初始化状态,来代替在构造函数里面初始化。
如果同时定义了 getDerivedStateFromProps 和 componentWillReceiveProps,只有 getDerivedStateFromProps 会被调用,同时 React 还会打印出警告信息。
还有一种情况就是,当状态发生变化的时候需要执行回调,这时候你就可以用 componentDidUpdate。
如果你觉得 static 不够优雅,你可以用下面这种方式定义,效果是一样的:
StrictMode
Strict mode 是新加入的组件,旨在引导你遵循最佳实践。把需要进行约束的组件簇放在它的下面就完事了:
完全一变相的 'use strict'
如果其下的组件不小心用了上文提到的要废除的生命周期方法,控制台会打印出错误信息(开发环境下):
错误信息提供的链接地址目前指向的是一个 RFC issue,也是因为生命周期方法被废除导致的。
AsyncMode
为了配合 StrictMode,异步组件支持现在重新命名为 React.unsafe_AsyncMode,它也会引发 StrictMode 的警告信息。
有关异步组件的使用可以参考以下博文:
新版 React 开发工具
新版本的开发工具也已经跟进,可以识别新加入的组件了。
但是 Chrome 上的插件还没有更新,还要等一段时间,所以 debug 的时候会看到很有趣的东西:
React. __SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED(译者注:红头组件,用了你就怕是要被炒鱿鱼了)表示不服。
Firefox 用户就有福了,完全支持:
可以看到 AsyncMode 组件可以直接被识别。
后日谈
总之呢,这还只是 alpha 版本,等稳定版本出来的时候可能会有点改动。根据 Dan 的说法,稳定版差不多下周就出:
讲道理,这不已经过了一个星期吗?
掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 Android、iOS、前端、后端、区块链、产品、设计、人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划、官方微博、知乎专栏。
[译] React 16.3(.0-alpha) 新特性的更多相关文章
- php5.3到php7.0.x新特性介绍
<?php /*php5.3*/ echo '<hr>'; const MYTT = 'aaa'; #print_r(get_defined_constants()); /* 5.4 ...
- [PHP] 从PHP 5.6.x 移植到 PHP 7.0.x新特性
从PHP 5.6.x 移植到 PHP 7.0.x 新特性: 1.标量类型声明 字符串(string), 整数 (int), 浮点数 (float), 布尔值 (bool),callable,array ...
- paip.php 5.0 5.3 5.4 5.5 -6.0的新特性总结与比较
paip.php 5.0 5.3 5.4 5.5 -6.0的新特性总结与比较 PHP5的新特性 2 · 对象的参照过渡是默认的(default) 3 · 引入访问属性的限制 3 · 引入访问方法的限 ...
- NodeJS 框架 Express 从 3.0升级至4.0的新特性
NodeJS 框架 Express 从 3.0升级至4.0的新特性 [原文地址:√https://scotch.io/bar-talk/expressjs-4-0-new-features-and-u ...
- 相比于python2.6,python3.0的新特性。
这篇文章主要介绍了相比于python2.6,python3.0的新特性.更详细的介绍请参见python3.0的文档. Common Stumbling Blocks 本段简单的列出容易使人出错的变动. ...
- MySQL 8.0 InnoDB新特性
MySQL 8.0 InnoDB新特性 1.数据字典全部采用InnoDB引擎存储,支持DDL原子性.crash safe,metadata管理更完善 2.快速在线加新列(腾讯互娱DBA团队贡献) 3. ...
- Atitit jquery 1.4--v1.11 v1.12 v2.0 3.0 的新特性
Atitit jquery 1.4--v1.11 v1.12 v2.0 3.0 的新特性 1.1. Jquery1.12 jQuery 2.2 和 1.12 新版本发布 - OPEN资讯.h ...
- React 16.3.0 发布,构建用户界面的 JavaScript 库
React 16.3.0 已发布,React 是 Facebook 推出的一个为数据提供渲染为 HTML 视图,用来构建用户界面的开源 JavaScript 库. React 视图通常采用包含以自定义 ...
- servlet3.0 的新特性之二注解代替了web.xml配置文件
servlet3.0 的新特性: 注解代替了 web.xml 文件 支持了对异步的处理 对上传文件的支持 1.注解代替了配置文件 1.删除了web.xml 文件 2. 在Servlet类上添加@Web ...
- C# 6.0/7.0 的新特性
转眼C#语言都已经迭代到7.0版本了,很多小伙伴都已经把C# 7.0 的新特性应用到代码中了,想想自己连6.0的新特性都还很少使用,今天特意搜集了一下6.0和7.0的一些新特性,记录一下,方便查阅. ...
随机推荐
- 【php】面向对象(三)
知识点关键词:FSCICATS一. f => final: a) 是一个修饰符,用来修饰类和成员方法 b) 使用final修饰符修饰的类不能被继承,使用final修饰符修饰的成员方法,不能被重写 ...
- Linux学习,path,环境变量的配置
方法一: 1.查看当前环境变量配置的所与信息 echo $PATH 注意: echo是输出的意思 加$表示它是一个变量 2.配置环境命令 PATH="$PATH":comdir 注 ...
- C语言学生管理系统完善版
#include<stdio.h>#include<string.h>#include <stdlib.h>#define M 100struct score ...
- java 字符串截取 - 最后带上mysql字符串截取比较
Java中的substring()方法有两个方法的重载,一个带一个参数的,一个带两个参数的. 第一种写法: substring(n);//从索引是n的字符开始截取,条件(n>=0,n<字符 ...
- 数据结构和算法(Golang实现)(2)简单入门Golang-包、变量和函数
包.变量和函数 一.举个例子 现在我们来建立一个完整的程序main.go: // Golang程序入口的包名必须为 main package main // import "golang&q ...
- Xray安装与使用
0×00 Xray简介 xray是从长亭洞鉴核心引擎中提取出的社区版漏洞扫描神器,支持主动.被动多种扫描方式,自备盲打平台.可以灵活定义 POC,功能丰富,调用简单,支持 Windows / macO ...
- SpringCloud入门(十): Config 统一配置中心
SpringCloud Config 简介 在分布式系统中,由于服务组件过多,为了方便争对不通的环境下的服务配置文件统一管理,实时更新,所以出现了分布式配置中心组件.市面上开源的配置中心有很多,360 ...
- 试验使用t检验
官方解释 Excel中使用T.TEST函数 T.TEST(array1,array2,tails,type) Array1 必需.第一个数据集. Array2 必需.第二个数据集. ...
- 给我Python几十行代码,我还你一个微信聊天助手
前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者: 故事胶片 PS:如有需要Python学习资料的小伙伴可以加点击下方链 ...
- stand up meeting 11/23/2015
组员 周末工作 工作耗时/h 明日计划 计划耗时/h 冯晓云 完成网络状况的侦听,对网络连接断开,WiFi状况不佳,未查询到结果设定不同的返回码,按约定格式返回:对于超时未查询进行了相关的学习: 3 ...