0

0

React中组件渲染使用详解

php中世界最好的语言

php中世界最好的语言

发布时间:2018-05-24 14:38:23

|

2134人浏览过

|

来源于php中文网

原创

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

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

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

import React from 'react'
let Login = (props) => {
    return ;
}
let Logout = (props) => {
    return ;
}
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 = 
        } else {
            button = 
        }
        return 

{button}

} }

效果预览

组件渲染 —— 列表渲染

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

列表渲染 —— 简单实现

import React from 'react'
import ReactDOM from 'react-dom'
let Component1 = () => {
    let lis = [
  • Javascript
  • ,
  • Vue
  • ,
  • React
  • ] return (

      {lis}

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

    列表渲染 —— 循环 for

    import React from 'react'
    import ReactDOM from 'react-dom'
    let Component1 = () => {
        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 = () => {
        let data = ['Javascript', 'Vue', 'React']
        let lis = data.map((frm) => {
            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 (
                

    { React.Children.map(this.props.children, function(childNode){ return

  • {childNode}
  • }) }

    ); } }) ReactDOM.render( Tom Sam , document.getElementById('p1'));

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

    推荐阅读:

    前端中排序算法实例详解

    Android游戏框架AndEngine使用入门 WORD版
    Android游戏框架AndEngine使用入门 WORD版

    本文档主要讲述的是Android游戏框架AndEngine使用入门;AndEngine是一款以OpenGLES方式进行画面渲染的2D游戏引擎,可以运行在支持Android 1.6及以上版本的系统当中。应该说,相较前文介绍的Libgdx引擎,AndEngine拥有更多的游戏组件与扩展功能。并且与Libgdx不同,它在默认情况下已经可以支持中文,采用屏幕坐标系绘也更符合一般Android绘图习惯。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

    下载

    PromiseA+的实现步骤详解

    相关专题

    更多
    C++ 高级模板编程与元编程
    C++ 高级模板编程与元编程

    本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

    10

    2026.01.23

    php远程文件教程合集
    php远程文件教程合集

    本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

    29

    2026.01.22

    PHP后端开发相关内容汇总
    PHP后端开发相关内容汇总

    本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

    21

    2026.01.22

    php会话教程合集
    php会话教程合集

    本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

    21

    2026.01.22

    宝塔PHP8.4相关教程汇总
    宝塔PHP8.4相关教程汇总

    本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

    13

    2026.01.22

    PHP特殊符号教程合集
    PHP特殊符号教程合集

    本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

    11

    2026.01.22

    PHP探针相关教程合集
    PHP探针相关教程合集

    本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

    8

    2026.01.22

    菜鸟裹裹入口以及教程汇总
    菜鸟裹裹入口以及教程汇总

    本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

    55

    2026.01.22

    Golang 性能分析与pprof调优实战
    Golang 性能分析与pprof调优实战

    本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

    9

    2026.01.22

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    React 教程
    React 教程

    共58课时 | 4万人学习

    国外Web开发全栈课程全集
    国外Web开发全栈课程全集

    共12课时 | 1.0万人学习

    React核心原理新老生命周期精讲
    React核心原理新老生命周期精讲

    共12课时 | 1万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

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