循环导入图像

时间:2018-06-27 03:36:55

标签: javascript html reactjs webpack

我要完成的工作是从正确的目录中导入每个文件。我的后端代码将文件保存到images目录,而我的前端目录是我存放React.js代码的地方。

我的目录结构可以在下面看到。

-- Backend
   -- backend code
-- Frontend
   -- frontend code
-- images
   -- user_1
      -- People.jpg
   -- user_2
      ...

如您所见,我正在从后端获取路径。 imagePath将类似于以下“ ../images/user_1/People.jpg”。我看到另一个stackoverflow post使用require关键字将图像存储在const变量中,但是使用该方法却收到错误消息。

@observer
export default class SnapCapsule extends React.Component {
  componentDidMount() {
    axios.get(`${this.props.domain}/snapcapsule`)
      .then(res => {
        res.data.map((capsule) => {
          var domainSize = this.props.domain.length+13;
          var imagePath = "../" + capsule["image"].substring(domainSize);
          var dateToPost = capsule["dateToPost"].substring(0, 10);
          var username = capsule["username"];
          console.log(capsule["caption"], imagePath, dateToPost, username);
          this.props.store.addCapsule(
            capsule["caption"],
            imagePath,
            dateToPost,
            username
          )
        })
      });
  }

  componentWillUnmount() {
    this.props.store.clear();
  }


  render() {
    const { capsules } = this.props.store;
    const capsuleList = capsules.map((capsule, i) => (
    <Col key={i} xs={6} md={4}>
      <Thumbnail src={capsule.imagePath} alt="242x200">
        <h3> {capsule.title} </h3>
        <p> @{capsule.username} </p>
      </Thumbnail>
    </Col>
  ));

return (
  <Grid>
    <Row>
      { capsuleList }

    </Row>
  </Grid>
);

}

    return (
      <Grid>
        <Row>
          { capsuleList }

        </Row>
      </Grid>
    );
  }
}

答案

不是提供目录中image标记的路径。我将backen配置为通过url检索照片。

capsule.imagePath => http://localhost:8000/snapcapsule/images/user_1/People.jpeg

2 个答案:

答案 0 :(得分:2)

我建议避免动态条件的动态需求。捆绑时,它可能不会包含所有图像,并且可能会引起问题。

在您的情况下,您正在从服务器中获取信息并尝试直接从文件夹中导入文件,这是不正确的方式。作为网络应用程序,您应该使用网络网址显示图片。

作为对capsuleList的响应,您具有图像路径。使用该路径,您的后端应处理请求并返回图像。这是后端责任。当React在浏览器上运行时,React没有访问文件夹的权限,但是您的后端可以访问文件夹。

在您的后端中,读取图像并将其存储。

答案 1 :(得分:0)

您应该能够直接在缩略图组件中实际引用这些图像,而无需将其导入为模块或类似的内容。

const path = "./../../images/user_1/People.jpg";
<Thumbnail src={path} ...