首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >显示React Skeleton Loader,直到图像完全加载

显示React Skeleton Loader,直到图像完全加载
EN

Stack Overflow用户
提问于 2019-07-09 16:08:26
回答 1查看 4.4K关注 0票数 2

我的组件中有一个react-loading-skeleton,我的页面中有一个使用img标签加载的静态图像,我想显示一个骨架组件,直到图像加载。我尝试了react.lazy和suspense,但它只显示到组件加载不起作用,直到图像完全加载。

代码语言:javascript
复制
import React from 'react';

export default class SlideItems extends React.Component {
    render() {
        return (
            <div>
                <img src={require("./someImg.jpg")}/>
            </div>
        );
    }
}

EN

回答 1

Stack Overflow用户

发布于 2019-07-09 16:51:44

首先将构造函数和状态添加到类中:

代码语言:javascript
复制
    constructor(props) {
     super(props);

     this.state = {
      image: '',
     }
    }

然后,您可以将onLoad属性添加到图像标签,如下所示:

代码语言:javascript
复制
<img src={require("./someImg.jpg")} onLoad={this.handleImageLoaded.bind(this)}/>

并创建处理图像加载的函数:

代码语言:javascript
复制
handleImageLoaded() {
    this.setState({ image: 'loaded' });
}

然后在render中可以执行如下操作:

代码语言:javascript
复制
render() {
 return (
  <div>
   {!this.state.image &&
    <SkeletonComponent/>
   }
   <img src={require("./someImg.jpg")} onLoad={this.handleImageLoaded.bind(this)}/>
  </div>
 );
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56948061

复制
相关文章

相似问题

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