登录  /  注册
首页 > web前端 > js教程 > 正文

React中组件渲染使用详解

php中世界最好的语言
发布: 2018-05-24 14:38:23
原创
1604人浏览过

这次给大家带来React中组件渲染使用详解,React中组件渲染使用的注意事项有哪些,下面就是实战案例,一起来看一下。

组件渲染 —— 条件渲染(动态组件)

很多情况下组件是动态渲染的,比如登录状态,如果已登录则显示退出登录,否则显示登录

import React from 'react'
let Login = (props) => {
    return <input>;
}
let Logout = (props) =&gt; {
    return <input>;
}
export default class CP extends React.Component{
    state = {
        status: 0
    }
    login(){
        this.setState({status: 1})
    }
    logout(){
        this.setState({status: 0})
    }
    render(){
        let button = null;
        if(this.state.status == 0){
            button = <login></login>
        } else {
            button = <logout></logout>
        }
        return <p>{button}</p>
    }
}
登录后复制

效果预览

组件渲染 —— 列表渲染

React 没有指令,所以在列表渲染时得借助数组来完成。

列表渲染 —— 简单实现

import React from 'react'
import ReactDOM from 'react-dom'
let Component1 = () =&gt; {
    let lis = [
登录后复制
  • Javascript
  • Vue
  • React
  • ]     return (         

                

                      {lis}             
                 ) } ReactDOM.render(          document.getElementById('app') )

    列表渲染 —— 循环 for

    import React from 'react'
    import ReactDOM from 'react-dom'
    let Component1 = () =&gt; {
        let data = ['Javascript', 'Vue', 'React']
        let lis = [];
        for(let frm of frms){
            lis.push(
    登录后复制
  • {frm}
  • )     }     return (         

                

                      {lis}             
                 ) } ReactDOM.render(          document.getElementById('app') )

    列表渲染 —— 循环 map

    import React from 'react'
    import ReactDOM from 'react-dom'
    let Component1 = () =&gt; {
        let data = ['Javascript', 'Vue', 'React']
        let lis = data.map((frm) =&gt; {
            return 
    登录后复制
  • {frm}
  •     });     return (         

                

                      {lis}             
                 ) } ReactDOM.render(          document.getElementById('app') )

    列表渲染 —— 对象数组

    import React from 'react'
    import ReactDOM from 'react-dom'
    class Component1 extends React.Component {
        constructor(props){
            super(props)
        }
        static defaultProps = {
            students: [
                {id: 1, name: 'Tom', age: 18, gender: 1}, 
                {id: 2, name: 'Sam', age: 22, gender: 1}, 
                {id: 3, name: 'Lucy', age: 20, gender: 0}
            ]
        }
        getKeys(item = {}){
            return Object.keys(item)
        }
        render(){
            return (
                
    登录后复制
                                                                  {                             this.getKeys(this.props.students[0]).map((key) => {                                 return                              })                         }                                                                            {                         this.props.students.map((obj) => {                             return (                                                                      {                                         this.getKeys(obj).map((key, idx) => {                                             return                                          })                                     }                                                              )                         })                     }                              
    {key}
    {obj[key]}
            )     } } ReactDOM.render(     ,     document.getElementById('app') )

    列表渲染 —— 键(Keys)

    因为 React 是虚拟 DOM 到真实 DOM 的一个过程,而 DOM 本身就是一个对象,对象默认没有唯一标识,所以需要手动指定。

    键(Keys) 帮助 React 标识哪个项被修改、添加或者移除了。数组中的每一个元素都应该有一个唯一不变的键(Keys)来标识。

    键(Keys)用到列表渲染中,同辈元素中必须是唯一的。

    组件渲染 —— 组件子节点

    因为组件的调用是将组件当成一个 DOM 节点使用,所以组件里面可以包含子节点。React 对组件的子节点通过 this.props.children 来获取,通常this.props.children会有以下几种情况

    1. 如果当前组件没有子节点,它就是 undefined

    2. 如果有一个子节点,数据类型是 object

    3. 如果有多个子节点,数据类型就是 array

    为了解决这种数据类型不一致导致在使用的过程中要不断判断的情况,React 提供了一个方法Reacth.Children来处理该属性。

    var Component1 = React.createClass({
        render: function(){
            return (
                <p>                        
                    {
                        React.Children.map(this.props.children, function(childNode){
                            return </p>
    登录后复制
  • {childNode}
  •                     })                 }                      );     } }) ReactDOM.render(              Tom         Sam     , document.getElementById('p1'));

    相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

    推荐阅读:

    前端中排序算法实例详解

    PromiseA+的实现步骤详解

    以上就是React中组件渲染使用详解的详细内容,更多请关注php中文网其它相关文章!

    智能AI问答
    PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
    来源:php中文网
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    最新问题
    关于CSS思维导图的课件在哪? 课件
    凡人来自于2024-04-16 10:10:18
    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送
    PHP中文网APP
    随时随地碎片化学习
    PHP中文网抖音号
    发现有趣的

    Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号