javascript - reactjs渲染列表没效果,帮我看一下哪里有问题
高洛峰
高洛峰 2017-04-11 13:30:01
[JavaScript讨论组]

用的typescript编译,axios处理异步,获取到数据之后渲染一个导航,不过我获取到之后并没有渲染出来 ,可以帮我看下问题出在哪吗?下面有标记没有按我想法运行代码的位置 谢谢
state有数据,console没报错

/// 

import * as React from 'react';
import * as axios from 'axios';

const styles = {
    container: {
        margin: '1rem'
    },
    h2: {
        fontWeight: 300,
        fontSize: '1.5rem'
    },
    techs: {
        display: 'flex',
        flexDirection: 'row',
        flexWrap: 'wrap',
        justifyContent: 'space-around'
    }
};

// 數據結構
class NavList {
    constructor(
        public name: string,
        public link: string
    ) {}
}

interface NavProps { };

interface NavState {
    nav: NavList[]
};

export class Navs extends React.Component {
    constructor() {
        super();
        this.state = { nav: [] };
    }

    componentDidMount() {
        axios
            .get('app/nav/nav.json')
            .then((response: Axios.AxiosXHR) => {
                this.setState({ nav: response.data });
            });
    }

    render() {
        return (
            
        );
    }
}

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(1)
PHPz

map方法遍历返回函数调用结果组成的新的数组, 因此在map方法中需要return标签元素, 返回渲染标签元素数组.

<a href={nav.link}>{nav.name}</a>

修改为

return (<a key={i} href={nav.link}>{nav.name}</a>)
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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