首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >为什么回取检索空白对象?

为什么回取检索空白对象?
EN

Stack Overflow用户
提问于 2018-06-08 08:27:08
回答 3查看 191关注 0票数 0

我有一个工作的Django REST,它返回如下:

代码语言:javascript
运行
复制
{
    "id": 1,
    "brand": "peugeot",
    "model": "3008",
    "variant": "allure"
}

我使用以下代码获取上述数据:

代码语言:javascript
运行
复制
render() {
        const { brand, model, variant } = this.props;
        let url = `http://127.0.0.1:8000/api/car/${brand}/${model}/${variant}/`;
        console.log(url) <== url is correct when checked in console
        fetch(url)
            .then(response => response.json())
            .then(data => data.length === 0 ? this.setState({
                data : data
            }) : null ) <== I have used a condition for setState to stop fetching infintely

        const { data } = this.state;
        console.log(data) <== This is a blank object with no data in console
        console.log(data.id) <== This is undefined in console
        return (
            <div>
                {data.id} <== No data is shown on webpage
                Car Details
            </div>
        );
    }

当我试图获取网页上的数据时,没有显示错误。我做错了什么?

当我有一个对象数组时,可以从同一个API服务器获取数据,并使用map循环数据。在这里,我试图获取一个项目,这样就没有数组,只有一个对象。我在语法上做错什么了吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-06-08 08:38:24

您不应该在fetch函数中使用rendersetState

由于滚动、点击、道具更改等各种副作用,render被多次调用,这种代码会引起各种麻烦。

如果需要执行一次请求,请在fetch中调用componentDidMount函数。另外,我认为你的回调应该是这样的:

代码语言:javascript
运行
复制
fetch(url)
  .then(response => response.json())
  .then(data => this.setState({ data : data }))

摘自文档

在安装组件后立即调用componentDidMount()。需要DOM节点的初始化应该放在这里。如果需要从远程端点加载数据,这是实例化网络请求的好地方。

票数 3
EN

Stack Overflow用户

发布于 2018-06-08 08:42:04

我将“setState”之前的条件更改为JSON.stringify(data) !== JSON.stringify(this.state.data),现在它起作用了。

票数 1
EN

Stack Overflow用户

发布于 2018-06-08 08:29:01

如果是:

代码语言:javascript
运行
复制
.then(data => data.length > 0 ? this.setState({ data }) : null )
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50756466

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档