我正在尝试显示来自base64字符串的图像,但它一直像这样显示:
我尝试打印img并得到如下信息:
我尝试通过执行<img src={this.state.img} />
仅显示它是错误的吗?感谢您的帮助!
编辑:我还更新了此帖子,以包含如何生成base64代码。本质上,我上传图像并使用https://www.npmjs.com/package/react-image-crop裁剪该图像。然后,我要显示裁剪的图像,这就是发生问题的地方
<div>
<input type="file" onChange={this.onSelectFile} />
</div>
onSelectFile = e => {
if (e.target.files && e.target.files.length > 0) {
const reader = new FileReader();
reader.addEventListener(
"load",
() =>
this.setState({
src: reader.result,
openCropper: true
}),
false
);
reader.readAsDataURL(e.target.files[0]);
}
};
function getCroppedImg(image, pixelCrop, fileName) {
const canvas = document.createElement('canvas');
canvas.width = pixelCrop.width;
canvas.height = pixelCrop.height;
const ctx = canvas.getContext('2d');
ctx.drawImage(
image,
pixelCrop.x,
pixelCrop.y,
pixelCrop.width,
pixelCrop.height,
0,
0,
pixelCrop.width,
pixelCrop.height
);
// As Base64 string
const base64Image = canvas.toDataURL('image/jpeg');
return base64Image;
答案 0 :(得分:1)
我相信您在base64 URL的末尾缺少等号。

答案 1 :(得分:1)
问题可能是由于调用onSelectFile
的上下文所致。当前,您将onSelectFile
定义为箭头函数。反过来,这意味着this.setState
将在您的FileReader
加载图像数据(然后尝试更新组件的状态)时未定义。
请考虑以下代码,概述可能的解决方案:
class App extends React.Component {
constructor(props) {
super(props)
this.state = {
src:''
}
}
// Define as class method rather than arrow function
onSelectFile(e) {
if (e.target.files && e.target.files.length > 0) {
const reader = new FileReader();
reader.addEventListener(
"load",
() =>
this.setState({
src: reader.result,
openCropper: true
}),
false
);
reader.readAsDataURL(e.target.files[0]);
}
}
render() {
return (
<div>
{/* invoke onSelectFile in this way to ensure calling context is
current component */}
<input type="file" onChange={(e) => this.onSelectFile(e)} />
<img src={this.state.src} />
</div>
)
}
}
ReactDOM.render(<App />, document.querySelector("#app"))
对于有效的演示,please see this jsFiddle-希望这会有所帮助!