react native基于expo上传图片组件expo-image-picker的使用

app中,需要新增一个用户上传图片功能,由于app项目基于expo搭建的,所以直接使用expo中的组件。

第一步:下载expo-image-picker

yarn add expo-image-picker

第二步:在对应的文件中导入

import * as ImagePicker from 'expo-image-picker';

第三步:上传方法(我这里用伪代码描述)

import React, { useState, useEffect } from 'react';
import { View, Button, Image } from 'react-native';
import * as ImagePicker from 'expo-image-picker';

export default function App() {
  const [selectedImage, setSelectedImage] = useState(null);

  const openImagePicker = async () => {
    let result = await ImagePicker.launchImageLibraryAsync({
        allowsEditing: true, // 图片是否可编辑
        quality: 0,
        mediaTypes:ImagePicker.MediaTypeOptions.Images, //打开相册
    });

    if (!result.cancelled) {
        console.log(result,'result');
        setSelectedImage(result.uri);
        //在这里进行与后端对接操作,一般来说这里需要组装一下数据传给后端。
        //打印的数据如下图
    }else{
        console.log('已取消上传')
    }
  };

  return (
    <View>
      <Button title="上传图片" onPress={openImagePicker} />
    </View>
  );
}

上传图片成功后的回调结果

 拿到assets后,组装成你想要的数据,返给后端拿到图片id再接着实现后面的功能。

这里注意IOS和安卓下的区别,IOS正常打开相册,安卓打开的是文件管理器。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 react-native-image-picker 实现头像上功能,需要先安装该库并链接到你的项目中。然后,可以按照以下步骤实现头像上功能: 1. 创建一个按钮,用于触发选择图片的操作。例如: ``` import React, { useState } from 'react'; import { Button, Image, StyleSheet } from 'react-native'; import ImagePicker from 'react-native-image-picker'; export default function AvatarPicker() { const [avatar, setAvatar] = useState(null); const pickAvatar = () => { ImagePicker.showImagePicker( { title: 'Select Avatar', storageOptions: { skipBackup: true, path: 'images', }, }, (response) => { if (response.didCancel) { console.log('User cancelled image picker'); } else if (response.error) { console.log('ImagePicker Error: ', response.error); } else { setAvatar(response.uri); } }, ); }; return ( <> {avatar && <Image source={{ uri: avatar }} style={styles.avatar} />} <Button title="Pick Avatar" onPress={pickAvatar} /> </> ); } const styles = StyleSheet.create({ avatar: { width: 100, height: 100, borderRadius: 50, }, }); ``` 2. 在 pickAvatar 函数中调用 ImagePicker.showImagePicker 方法。这个方法接受一个选项对象和一个回调函数作为参数。选项对象可以设置一些选项,例如标题、存储选项等等。回调函数会在用户选择或拍摄一张照片后被调用,它接受一个 response 对象作为参数,该对象包含有关所选图像的信息。 3. 在回调函数中,可以根据 response 对象的属性来处理所选图像。例如,如果用户取消了选择,可以在控制台中打印一条消息。如果选择了图像,可以使用 setAvatar 方法将图像的 URI 存储在组件的状态中。 4. 最后,可以使用所选图像的 URI 来显示图像。在上面的示例中,使用 Image 组件来显示图像。 5. 将所选图像上到服务器。可以使用 fetch 或 axios 等库将图像上到服务器。在上之前,可能需要将图像压缩或调整大小以减少输时间和带宽使用
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值