【场景实现】React+material-ui+typescript实现H5上传身份证后显示图片 ,FileReader.readAsDataURL()方法读取图像信息

原理

readAsDataURL方法用于读取指定的内容File。读取操作完成后,readyState变成DONE,并loadend触发。那时,该result属性包含数据作为数据:URL表示文件数据为base64编码的字符串。

举个栗子

HTML

<input type="file" onchange="previewFile()"><br>
<img src="" height="200" alt="Image preview...">

Javascript

function previewFile() {
  const preview = document.querySelector('img');
  const file = document.querySelector('input[type=file]').files[0];
  const reader = new FileReader();

  reader.addEventListener("load", function () {
    // convert image file to base64 string
    preview.src = reader.result;
  }, false);

  if (file) {
    reader.readAsDataURL(file);
  }
}

本文场景:上传身份证

在这里插入图片描述
HTML

 <FormItem label="身份证国徽面">
            <>
            <div className={classes.upload}>
                <input className={classes.input} type="file" accept="image/*" onChange={onChoose}/>
                        <ButtonBase
                            focusRipple
                            className={classes.uploadBtn}
                            component="span"
                        >
                        <img src={img3} className={classes.img2} alt=""></img>
                        </ButtonBase>
            </div>
            {selectedImg?
            <div className={classes.cropperContainer}>
                <img
                    className={classes.cropperImg}
                    src={selectedImg}
                    alt=""
                />
            </div>
            :''}
   </>

CSS

 upload:{
        width: '100%',
        height: '100%',
        position:'relative',
        border: '1px dashed rgba(232,232,232,1)',
        overflow: 'hidden'
    },
    input: {
        width: theme.typography.pxToRem(342),
        height: theme.typography.pxToRem(181),
        position:'absolute',
        display: 'none'
    },
    uploadBtn: {
        display: 'flex',
        width: '100%',
        height: '100%',
        alignItems: 'center',
        textAlign: 'center'
    },
    cropperContainer: {
        position:'absolute',
        width: theme.typography.pxToRem(342),
        height: theme.typography.pxToRem(181),
    },
    cropperImg: {
        width: theme.typography.pxToRem(342),
        height: theme.typography.pxToRem(181),
    },

Javascript

const [currency, setCurrency] = React.useState('EUR');
const [selectedImg, setSelectedImg] = useState<undefined | string>();

const onChoose = (e: any) => {
    e.persist();
    e.preventDefault();
    let files;
    if (e.dataTransfer) {
        files = e.dataTransfer.files;
    } else if (e.target) {
      files = e.target.files;
    }
    const reader = new FileReader();
    reader.onload = () => {
            setSelectedImg(reader.result as string);
            // setModalVisible(true);
            e.target.value = '';
    };
    reader.readAsDataURL(files[0]);
    setCurrency('EUR')
  };
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
使用React和Ant Design来实现一个用户管理功能非常简单。首先,我们需要创建一个React应用程序。可以使用脚手架工具(如Create React App)来快速搭建起一个React应用的基本结构。 1. 创建React应用程序 使用以下命令来创建一个新的React应用程序: ``` npx create-react-app user-management cd user-management ``` 2. 安装Ant Design 在项目根目录下运行以下命令来安装Ant Design依赖项: ``` npm install antd ``` 3. 集成Ant Design组件 编辑src/App.js文件,导入所需的Ant Design组件并编写用户管理功能的代码。以下是一个简单的示例: ```jsx import React, { useState } from 'react'; import { Table, Button, Modal, Form, Input } from 'antd'; const App = () => { const [users, setUsers] = useState([]); const [isModalVisible, setIsModalVisible] = useState(false); const columns = [ { title: '姓名', dataIndex: 'name', key: 'name' }, { title: '年龄', dataIndex: 'age', key: 'age' }, { title: '操作', key: 'action', render: (text, record) => <Button onClick={() => deleteUser(record.key)}>删除</Button> } ]; const [form] = Form.useForm(); const addUser = () => { form.validateFields().then(values => { const user = { name: values.name, age: values.age, key: users.length + 1 }; setUsers([...users, user]); form.resetFields(); setIsModalVisible(false); }); }; const deleteUser = (key) => { setUsers(users.filter(user => user.key !== key)); }; return ( <div> <Button onClick={() => setIsModalVisible(true)}>添加用户</Button> <Table dataSource={users} columns={columns} /> <Modal title="添加用户" visible={isModalVisible} onCancel={() => setIsModalVisible(false)} onOk={addUser}> <Form form={form}> <Form.Item name="name" label="姓名" rules={[{ required: true }]}> <Input /> </Form.Item> <Form.Item name="age" label="年龄" rules={[{ required: true }]}> <Input /> </Form.Item> </Form> </Modal> </div> ); }; export default App; ``` 4. 运行应用 使用以下命令来运行应用程序: ``` npm start ``` 应用程序将在浏览器中自动打开。您现在就可以通过点击“添加用户”按钮来添加用户,点击“删除”按钮来删除用户,并且可以通过Ant Design的Table组件显示用户列表。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

椰卤工程师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值