实现react组件的递归调用

栏目: IOS · Android · 发布时间: 6年前

内容简介:导语: 项目中有侧边栏的层级菜单或者需要根据接口生成DOM树等操作时,如何实现组件的递归调用呢?项目中有侧边栏的层级菜单或者需要根据接口生成DOM树等操作时,这里就需要用到了组件的递归调用。在本篇文章里,我们使用React来简单实现下组件的递归。在React可以通过props和children来向子组件传递信息,不过在这里大致的思路都是一样的。我们先定义一下要渲染的json结构:

导语: 项目中有侧边栏的层级菜单或者需要根据接口生成DOM树等操作时,如何实现组件的递归调用呢?

项目中有侧边栏的层级菜单或者需要根据接口生成DOM树等操作时,这里就需要用到了组件的递归调用。

在本篇文章里,我们使用React来简单实现下组件的递归。在React可以通过props和children来向子组件传递信息,不过在这里大致的思路都是一样的。我们先定义一下要渲染的json结构:

list = [
    {
        name: '1',
        children: [
        {
            name: '1-1'
        },
        {
            name: '1-2',
            children: [
            {
                name: '1-2-1'
            }
            ]
        },
        {
            name: '1-3'
        }
        ]
    },
    {
        name: '2',
        children: [
        {
            name: '2-1'
        }
        ]
    }
]

我们的Item组件可以这样实现:

render() {
    const list: any = this.props.children || [];
    return (
        <div className="item">
            {
                list.map((item: ItemData, index: number) => {
                    return <React.Fragment key={index}>
                        <h3>{item.name}</h3>
                        {
                            // 当该节点还有children时,则递归调用本身
                            item.children && item.children.length ?
                            <Item>{item.children}</Item> : null
                        }
                    </React.Fragment>
                })
            }
        </div>
    )
}

最后调用这个Item组件:

<Item>{this.list}</Item>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Growth Hack 這樣做

Growth Hack 這樣做

Xdite / PCuSER電腦人文化 / 2016-5-7 / 300.00台幣

◎具體教你在預算有限的情況之下,把成長做出來的可行與必要方法! ◎帶動台灣成長駭客話題的專業講師,親授讓產品突破80分的成長秘笈 @這本書要給誰看? 1. 創業者、個人品牌經營者,想要提高自己服務轉換率的人。 2. 空有產品,但是賣不出去,花了錢投廣告卻效果低落的人。 @這本書有什麼不一樣? 1.全球最重要的趨勢,台灣最知名的 Growth Hack 講師 Xd......一起来看看 《Growth Hack 這樣做》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具