我正在React中制作一个小应用程序,使用Axios获取随机图像。我正在使用React-bootstrap来设置图像的样式,但是在图像加载完成之前,会显示一个半小时的白色框。我该如何解决这个问题?在完成api调用之前显示的React-bootstrap样式
这是我的代码:
import React, { Component } from 'react';
import axios from 'axios';
import { Link } from 'react-router-dom';
import { Image, Button } from 'react-bootstrap';
const ROOT_URL = 'myurl'
export default class WhatDog extends Component {
constructor(props){
super(props);
this.state = { randomImg: '' };
}
componentDidMount(){
axios.get(ROOT_URL)
.then(res => {
const data = res.data.message
this.setState({ randomImg: data })
})
}
renderImage(){
return(
<div>
<Image src={this.state.randomImg} className="img" thumbnail/>
<Link to="/">
<Button bsStyle="danger" bsSize="large">Go back</Button>
</Link>
</div>
)
}
render() {
return (
<div className="App">
{
(this.state.randomImg === '')
? <div>
<h1>Loading...</h1>
</div>
: <div>
{this.renderImage()}
</div>
}
</div>
);
}
}
你没有看到** Loading ... **? –
我看到加载,但我也看到它下面的小空白框。 – FakeEmpire
图像需要一些时间,直到它实际上完成由浏览器加载。 – webdeb