React 17.0.1 - 使用动态路径导入组件

如何解决React 17.0.1 - 使用动态路径导入组件

我正在尝试学习如何使用 this guide 使用“useState”挂钩,但我似乎无法使用动态路径导入图像,因此当我单击按钮时,元素会获得新路径并发生变化图像。

以下是该指南导入图像的方式:

...
function App() {
  const [firstDieResult,setFirstDieResult] = useState(1);
  const [secondDieResult,setSecondDieResult] = useState(6);
  
  const firstDieImage = require(`./assets/${firstDieResult}.png`);
  const secondDieImage = require(`./assets/${secondDieResult}.png`);
...

但是,当我尝试以这种方式导入图像时,它不会导入它们。我是这样导入它们的:

import React,{useState} from 'react';
import './App.css';
import firstDieImage from './assets/1.png'
import secondDieImage from './assets/2.png'

function App() {
...

但是当我以这种方式导入它们时,我无法导入动态路径(例如 import firstDieImage from './assets/${firstDieResult}.png')。

如何以这种方式导入图像?
感谢您抽出宝贵时间。

完整代码供参考:

import React,{useState} from 'react';
import './App.css';
import firstDieImage from './assets/1.png'
import secondDieImage from './assets/2.png'

function App() {

  const [firstDieResult,setFirstDieResult] = useState(1)
  const [secondDieResult,setSecondDieResult] = useState(6)
  console.log(secondDieResult)
  
  //Commented out parts work in the guide,but not for me
  //const firstDieImage = require('./assets/1.png')
  //const secondDieImage = require('./assets/2.png')
  //const firstDieImage = require('./assets/${firstDieResult}.png')
  //const secondDieImage = require('./assets/${secondDieResult}.png');

  return (
    <div className="App">
      <header className="App-header">
        <div style={{ display: 'flex',margin: 20 }}>
          <img src={firstDieImage} className="die" alt="Die one" />
          <img src={secondDieImage} className="die" alt="Die two" />
        </div>
        <span>firstDieResult + secondDieResult</span>
        <button className="button">Roll</button>
      </header>
    </div>
  );
}

export default App;

解决方法

您的代码有误。

const firstDieImage = require('./assets/${firstDieResult}.png')

您应该使用反引号字符 (`) 而不是单引号 (')。如果您使用 create-react-app 模块创建项目,请像这样更新代码:

const firstDieImage = require(`./assets/${firstDieResult}.png`).default

您可以在此 git repo 中找到工作代码。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?