ReactNative实现图片上传功能(兼容安卓和ios)

最近在学习ReactNative,ReactNative可以基于目前大热的开源JavaScript库React.js来开发iOS和Android原生App,今天就学习一下ReactNative实现图片上传功能 在查看ReactNative的官方文档的时候,你会发现其实Fackbook是没有提供图片上传功能的。 如果我们的项目里需要使用图片上传(用js 实现图片上传),那我们有没有什么办法呢? 通过搜索React-native的github, 会发现里面有这么一篇文章:github.com/facebook/re...
解决方案: 采用FormData来实现,FormData 的API参考:developer.mozilla.org/zh-CN/docs/... 利用FormData对象,你可以使用一系列的键值对来模拟一个完整的表单,然后使用XMLHttpRequest发送这个"表单".

那么我们就来看看在RN里怎么做,贴代码:

js 复制代码
function uploadImage(uri) { // 参数为图片本地路径
  let formData = new FormData();
  let file = {uri: uri, type: 'multipart/form-data', name: 'a.jpg'};

  formData.append('images', file);

  fetch(url, {
    method: 'POST',
    headers: {
      'Content-Type': 'multipart/form-data',
    },
    body: formData,
  })
    .then(response => response.text())
    .then(responseData => {
      console.log('responseData', responseData);
    })
    .catch(error => {
      console.error('error', error);
    });
}
  1. 首先我们new了一个FormData
  2. 创建一个file对象,uri是什么?如下示例: Android图片路径示例: file:///storage/emulated/0/Pictures/eb645893-4c00-44a3-a9b4-a2116e955f7c.jpg ios图片路径示例: /Users/ashleydw/Library/Developer/CoreSimulator/Devices/23EE88D0-6E91-43AD-A3B6-06F87698C5A8/data/Containers/Data/Application/A73E68D3-7424-4301-9934-AD0F8251C1EB/tmp/7803DA8A-0E40-4FCB-A593-884805878172.jpg
  3. 设置header
js 复制代码
'Content-Type':'multipart/form-data', 
  1. 将创建好的FormData赋值给body

这样我们就完成了图片上传的功能。

各位也可以参考我这篇文章做个拍照功能,拍照完成后得到图片的url本地地址,然后结合这篇文章做个拍照上传服务器功能

也可以参考这篇文章将图片剪切后得到url本地地址,然后剪切完成后上传至服务器

相关推荐
zengyuhan5031 小时前
Windows BLE 开发指南(Rust windows-rs)
前端·rust
醉方休1 小时前
Webpack loader 的执行机制
前端·webpack·rust
前端老宋Running1 小时前
一次从“卡顿地狱”到“丝般顺滑”的 React 搜索优化实战
前端·react.js·掘金日报
隔壁的大叔1 小时前
如何自己构建一个Markdown增量渲染器
前端·javascript
用户4445543654261 小时前
Android的自定义View
前端
WILLF1 小时前
HTML iframe 标签
前端·javascript
枫,为落叶2 小时前
Axios使用教程(一)
前端
小章鱼学前端2 小时前
2025 年最新 Fabric.js 实战:一个完整可上线的图片选区标注组件(含全部源码).
前端·vue.js
ohyeah2 小时前
JavaScript 词法作用域、作用域链与闭包:从代码看机制
前端·javascript
流星稍逝2 小时前
手搓一个简简单单进度条
前端