我的问题:
我该如何获取一个.svg文件并使用<svg>
标签,以便我也可以交互式地样式化它(例如,在悬停时),而不是像我在示例中那样使用<img>
标签?
目标:
创建一个缩略图视图,显示主路线'/'
上每个国家的国旗(共149个)
问题:
我在Express代码中设置了静态路由,以使所有国旗都可用。
server.js:
app.use('/flags', express.static(FLAGS_FILES));
app.get('/flags', async (req, res) => {
let myFlags;
await readdir('data/flag-icons/')
.then((flags) => myFlags = flags)
.catch(err => console.log('Error:', err))
res.json(myFlags)
});
在客户端,我想获取每个 .svg 文件并将其内嵌到我的组件中。
我的 React 组件如下所示:
MapThumbnail 组件:
render(){
const {flagcode} = this.props;
const filepath = `/flags/${mapcode}/vector.svg`;
console.log('filepath:', filepath);
return (
<MapThumbnailStyle>
<img src={filepath}
alt={flagcode}
title={flagcode}
width='40px'
height='40px'
/>
</MapThumbnailStyle>
);
}