Изображение не видно (источник не распознан) - PullRequest
0 голосов
/ 02 июня 2018

Я делаю простое веб-приложение в React.js (+ Spring in back).

У меня проблема с отображением фотографии (.img) с локального пути в функции displayItems .Картинка не видна.Если я загружаю файл из сети в том же коде (src = "http ......."), все в порядке.

Не могли бы вы помочь?

import React, { Component } from 'react';
import '../index.css';

class Author extends Component {

constructor(props) {
    super(props);
    this.state = {
        mail: window.location.href.slice(32, -7),
        items: 2,
        loadingState: false
    };
    this.handleChange = this.handleChange.bind(this);
}

componentDidMount() {
    this.refs.iScroll.addEventListener("scroll", () => {
        if (this.refs.iScroll.scrollTop + this.refs.iScroll.clientHeight >=this.refs.iScroll.scrollHeight){
            this.loadMoreItems();
        }
    });

}

displayItems() {
    var items = [];
    for (let i = 0; i < this.state.items; i++) {
        //PROBLEM
        items.push(<img src="../resources/Photos/1.jpg"></img>);
    }
    return items;
}

loadMoreItems() {
    this.setState({ loadingState: true });
    setTimeout(() => {
        this.setState({ items: this.state.items + 2, loadingState: false });
    }, 3000);
}

render() {
    return (
          <div
              className="vc"
              ref="iScroll"
              style={{ height: "200px", overflow: "auto" }}
          >
              <h2>My adventures: </h2>
              <div>
                  {this.displayItems()}
              </div>
              {this.state.loadingState
              ? <p className="loading">
              loading More Images..
              </p>
              : ""}
          </div>
    );
}
}
export default Author;

1 Ответ

0 голосов
/ 02 июня 2018

Вам нужно будет получить изображение с помощью require или import и затем использовать его в src,

const image = require("../resources/Photos/1.jpg")

...

items.push(<img src={image}></img>);
...