使用react-native-image-crop-picker上传图片

41 篇文章 0 订阅
6 篇文章 0 订阅

使用reac-native的图片上传插件image-crop-picker上传图片的时候遇到了好多坑,真是把我坑惨了。

安装

安装可以参考插件提供的方法去安装。需要注意的是,如果android或者ios是有人负责的话就不要link了。link会自动关联代码会把客户端的代码变的不是你想要的。

调用相册

import ImagePicker from 'react-native-image-crop-picker';
async function openImage(){
 let image = await ImagePicker.openPicker({
        width: 750,
        height: 750,
        cropping: true
    });
}
//返回image对象,其中path就是剪切之后的图片地址

这个地方问题不大,有问题也可以去网上找找。

上传图片

这个地方要注意一下:

1.使用formdata去上传图片
2.上传文件的格式是固定的,除了uri以外的值不要变
3.这里的loading是用来控制loading动画的
4.实际的上传地址是类似”/Users/path/devices/xxxxx.jpg”这样的

let data = new FormData();
let file = { uri: image.path, type: "multipart/form-data", name: "image.png" };
data.append("imgFile", file);

try {
   let res = await uploadImage("/uploadImg.do", data);
   this.setState({
       loading: false
   });
   console.log(res)
   toast("上传成功!");
} catch (err) {
   console.log(err)
   toast("图片太大,请重新选择");
      this.setState({
        loading: false
      });
}
let uploadImage=async function(url,data){
    return await fetch(url, {
    method: 'POST',
    headers: {
      'Content-Type': 'multipart/form-data;charset=utf-8'
    },
    body: data
  });
}

上传成功

查看日志是否成功

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
使用 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 等库将图像上传到服务器。在上传之前,可能需要将图像压缩或调整大小以减少传输时间和带宽使用

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

疯狂紫萧

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

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

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

打赏作者

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

抵扣说明:

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

余额充值