React中条件渲染的示例分析-创新互联
小编给大家分享一下React中条件渲染的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
成都创新互联专注于梧州企业网站建设,响应式网站开发,商城网站制作。梧州网站建设公司,为梧州等地区提供建站服务。全流程定制制作,专业设计,全程项目跟踪,成都创新互联专业和态度为您提供的服务前言
在React中,你可以创建不同的组件各自封装你需要的东西。之后你可以只渲染其中的一部分,这取决于应用的state(状态)。
条件渲染
可以根据state的值进行组件的条件渲染。例如:
function Greeting(props) { const isLoggedIn = props.isLoggedIn; if (isLoggedIn) { return; } return ; } ReactDOM.render( // Try changing to isLoggedIn={true}: , document.getElementById('root') );
你还可以用变量去存储组件,以便进行条件筛选,使得渲染函数的返回值更加清爽,例如:
class LoginControl extends React.Component { constructor(props) { super(props); this.handleLoginClick = this.handleLoginClick.bind(this); this.handleLogoutClick = this.handleLogoutClick.bind(this); this.state = {isLoggedIn: false}; } handleLoginClick() { this.setState({isLoggedIn: true}); } handleLogoutClick() { this.setState({isLoggedIn: false}); } render() { const isLoggedIn = this.state.isLoggedIn; let button = null; if (isLoggedIn) { button =; } else { button = ; } return ( ); } } ReactDOM.render({button} , document.getElementById('root') );
还可以使用短操作符来实现条件筛选,可以用更短的代码写出渲染结果。例如&&来替代if,?:来替代if else, 例如:
function Mailbox(props) { const unreadMessages = props.unreadMessages; return (); } const messages = ['React', 'Re: React', 'Re:Re: React']; ReactDOM.render(Hello!
{unreadMessages.length > 0 &&You have {unreadMessages.length} unread messages.
}, document.getElementById('root') );
render() { const isLoggedIn = this.state.isLoggedIn; return (The user is {isLoggedIn ? 'currently' : 'not'} logged in.); }
这种跟更大的表达式的写法也可以,但是不推荐,因为代码就不是很直观了。
render() { const isLoggedIn = this.state.isLoggedIn; return ({isLoggedIn ? (); }) : ( )}
如果组件有时候需要渲染出来,而有时候不需要渲染出来,在不需要渲染的时候返回null即可。例如:
function WarningBanner(props) { if (!props.warn) { return null; } return (Warning!); } class Page extends React.Component { constructor(props) { super(props); this.state = {showWarning: true} this.handleToggleClick = this.handleToggleClick.bind(this); } handleToggleClick() { this.setState(prevState => ({ showWarning: !prevState.showWarning })); } render() { return (); } } ReactDOM.render(, document.getElementById('root') );
看完了这篇文章,相信你对“React中条件渲染的示例分析”有了一定的了解,如果想了解更多相关知识,欢迎关注创新互联网站建设公司行业资讯频道,感谢各位的阅读!
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
名称栏目:React中条件渲染的示例分析-创新互联
链接地址:http://pwwzsj.com/article/dhijcc.html