React16新特性
React的16版本采用了MIT开源许可证,新增了一些特性。
1. 使用Error Boundary处理错误组件之前,一旦某个组件发生错误,整个组件树将会从根节点被unmount下来。React 16修复了这一点,引入了Error Boundary的概念,中文译为“错误边界”,当某个组件发生错误时,我们可以通过Error Boundary捕获到错误并对错误做优雅处理,如使用Error Boundary提供的内容替代错误组件。Error Boundary可以看作是一种特殊的React组件,新增了componentDidCatch这个生命周期函数,它可以捕获自身及子树上的错误并对错误做优雅处理,包括上报错误日志、展示出错提示,而不是卸载整个组件树。(注:它并不能捕获runtime所有的错误,比如组件回调事件里的错误,可以把它想象成传统的 //最佳实践:将ErrorBoundary抽象为一个公用的组件类 import React,{ Component } from ‘react‘ export default class ErrorBoundary extends Component { constructor(props) { super(props) this.state = { hasError: false } } componentDidCatch(err,info) { this.setState({ hasError: true }) //sendErrorReport(err,info) } render(){ if(this.state.hasError){ return <div>Something went wrong!</div> } return this.props.children } }
我们可以在容易出错的组件外使用ErrorBoundary将它包裹起来,如下 //使用方式 render(){ return ( <div> <ErrorBoundary> <Profile user={this.state.user} /> </ErrorBoundary> <button onClick={this.onClick}>Update</button> </div> ) }
如果Profile组件发生错误,将会使用ErrorBoundary提供的 2. render方法新增返回类型在React 16中,render方法支持直接返回string,number,boolean,null,portal,以及fragments(带有key属性的数组),这可以在一定程度上减少页面的DOM层级。 //string render(){ return ‘hello‘ } //number render(){ return 88888 } //boolean render(){ return istrue?true:false } //null render(){ return null } //fragments,未加key标识符,控制台会出现warning render(){ return [ <div>hello</div>,<span>world</span>,<p>oh</p> ] }
以上各种类型现在均可以直接在render中返回,不需要再在外层包裹一层容器元素,不过在返回的数组类型中,需要在每个元素上加一个唯一且不变的key值,否则控制台会报一个warning。 3.使用createPortal将组件渲染到当前组件树之外Portals机制提供了一种最直接的方式可以把一个子组件渲染到父组件渲染的DOM树之外。默认情况下,React组件树和DOM树是完全对应的,因此对于一些Modal,Overlay之类的组件,通常是将它们放在顶层,但逻辑上它们可能只是属于某个子组件,不利于组件的代码组织。通过使用createPortal,我们可以将组件渲染到我们想要的任意DOM节点中,但该组件依然处在React的父组件之内。带来的一个特性就是,在子组件产生的event依然可以被React父组件捕获,但在DOM结构中,它却不是你的父组件。对于组件组织,代码切割来说,这是一个很好的属性。 //实现一个简易蒙层效果,抽象出一个通用的Overlay组件 import React,{ Component } from ‘react‘; import ReactDOM from ‘react-dom‘; export default class Overlay extends Component { constructor(props) { super(props); this.container = document.createElement(‘div‘); document.body.appendChild(this.container); } componentWillUnmount() { document.body.removeChild(this.container); } render() { return ReactDOM.createPortal( <div className=‘overlay‘> <span className=‘overlay-close‘ onClick={this.props.onClose}>×</span> {this.props.children} </div>,this.container ) } } //该组件对应的样式如下 .overlay{ box-sizing:border-box; position: fixed; top:50%; left:50%; width:260px; height:200px; margin-left:-130px; margin-top:-100px; padding:10px; background-color: #fff; outline: rgba(0,0,.5) solid 9999px; } .overlay-close{ position: absolute; top:10px; right:10px; color:red; cursor: pointer; }
使用方式如下: class App extends Component { constructor(props) { super(props); this.state = { overlayActive: false } this.cloSEOverlay = this.cloSEOverlay.bind(this); this.showOverlay = this.showOverlay.bind(this); } cloSEOverlay() { this.setState({ overlayActive: false }) } showOverlay() { this.setState({ overlayActive: true }) } render() { return ( <div className="App"> <div>hello world!</div> {this.state.overlayActive && <Overlay onClose={this.cloSEOverlay}>overlay content</Overlay>} <button onClick={this.showOverlay}>show</button> </div> ); } }
效果如图:
?
QQ截图20171109221918.png
4.支持自定义DOM属性在之前的版本中,React会忽略无法识别的HTML和SVG属性,自定义属性只能通过 //错误写法 render(){ return( <div a={()=>{}} onclick={this.showOverlay}></div> ) ) //Warning: Invalid event handler property `onclick`. Did you mean `onClick`? //Warning: Invalid value for prop `a` on <div> tag. Either remove it from the element,or pass a string or number value to keep it in the DOM.
现在class和tabindex等属性可以被传递给DOM,但依然会报一个Warning,建议使用标准的驼峰式className,tabIndex等。 5.setState传入null时不会再触发更新比如在一个选择城市的函数中,当点击某个城市时,newValue的值可能发生改变,也可能是点击了原来的城市,值没有变化,返回null则可以直接避免触发更新,不会引起重复渲染,不需要在shouldComponentUpdate函数里面去判断。 selectCity(e){
const newValue = e.target.value; this.setState((state)=>{ if(state.city===newValue){ return null; } return {city:newValue} }) )
注意:现在setState回调(第二个参数)会在 6.更好的服务器端渲染React 16的SSR被完全重写,新的实现非常快,接近3倍性能于React 15,现在提供一种流模式streaming,可以更快地把渲染的字节发送到客户端。另外,React 16在 7.新的打包策略新的打包策略中去掉了
写在最后,React 16采用了新的核心架构React Fiber。官方解释是“React Fiber是对核心算法的一次重新实现”。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- Swift 中使用 SwiftyJSON 制作一个比特币价格 APP
- c# – NullReferenceException,在挂钩SetConsoleCtrlHandle
- c# – 如何删除dbo.AspNetUserClaims和dbo.AspNetUserLogin
- 《剑指offer》:[53]正则表达式匹配
- C函数是否支持任意数量的参数?
- 没有变量的Ruby 1.9块
- 【Oracle 12c】CUUG OCP认证071考试原题解析(32)
- 正则表达式匹配2位数字
- c# – 添加新记录时,Windows窗体上不显示Visual Studio SQL
- ruby-on-rails – Helper Devise:在请求环境中找不到`Ward