{editing ? (
<input
type="file"
accept=".jpg, .jpeg, .png"
onChange={(e: any) => this.handleImageChange(e)} />
) : null}
原生输入框改变事件 ,采用异步方式.。
URL.createObjectURL把图片转成base64位编码格式展示。
通过this.props.onChange(file)调用上传方法。
async handleImageChange(e: any) {
const url = URL.createObjectURL(e.target.files[0])
const file = e.target.files[0]
await this.props.onChange(file)
this.setState({ url })
}
redux部分
export default connect<{}, StateProps>(
Overview,
{ styles },
{
mapModelToProps(customer, { storeId, customerId }, editing) {
return {
customer,
storeId,
customerId,
editing,
}
},
mapChangeToProps: {
onChange: handler => (values: any) => handler(values, "avatar"),
},
},
)
添加折扣的接口请求和页面: