004-React-Native--多图选择上传
参考资料:http://www.jianshu.com/p/488e62ed9656
一:使用react-native-image-crop-picker进行图片选择时,并没有提供多图的机制。
当你从相机选择图片时,会覆盖之前已经存在的图片。所以,今天,来一个多图选择并上传的例子,此例子中,会保存你之前已经选择的图片。例如,当前列表已经存在一张照片,当你去相册或者使用相机进行拍照时,不会覆盖当前列表已经存在的照片。二:使用FormData进行图片上传,并根据需要进行其他参数的添加
三: Coding
pic.gif//第三方库,需要使用npm引入
import ImagePicker from 'react-native-image-crop-picker';
import ActionSheet from '../../components/ActionSheet/ActionSheet'
import Config from '../../../Config' import ModalProgress from '../../components/Progress/ModalProgress' //存放数组
var dataToPost = []; export default class LoadingPage extends React.Component {
static navigationOptions = ({ navigation }) => {
const {state} = navigation;
return {
title: '上传信息',
headerRight: (
<Button
title="上传"
onPress={()=>{
state.params.commitPage();
}}
/>
),
};
}; componentWillMount(){
this.props.navigation.setParams({
commitPage:this.commitPage,
})
}
constructor(props){
super(props);
this.state={
images: [],
}
}
show() {
let items = [
{title: '从相册选取', onPress: () => this.openPicLib()},
{title: '拍照一张',onPress: () => this.pickSingleWithCamera()},
];
let cancelItem = {title: '关闭'};
ActionSheet.show(items, cancelItem);
} render(){
return(
<ScrollView>
<View>
<View>
<View style={styles.viewPadding}>
{this.createImageItem()}
</View>
</View>
<View style={styles.itemLine}/>
</View>
</ScrollView>
)
} createImageItem(){
let imageSource = require('../../imgs/upload.png');
let mainView;
if(this.state.images!=null&&this.state.images.length>=9){
mainView=null;
}else{
mainView= <TouchableOpacity
onPress={()=>{
this.show();
}}>
<Image source={imageSource} />
</TouchableOpacity>
} return(
<View>
<View>
{this.state.images ? this.state.images.map(i => <View key={i.uri}>{this.renderImage(i)}</View>) : null}
</View>
<View>
{mainView}
</View>
</View>
)
} //从相机获取图片
pickSingleWithCamera=()=> {
ImagePicker.openCamera({
cropping: false,
width: Math.round((Dimensions.get('window').width-20)),
height: 300,
}).then(image => {
dataToPost.push({
uri: image.path,
width: image.width,
height: image.height,
});
this.setState({
images: dataToPost
});
}).catch(
e => alert(e)
);
} //从图库或者相机进行获取,因为安卓平台不能进行多图选择,所以,需要区分不同平台
openPicLib=()=> {
if(Platform.OS === 'ios'){
ImagePicker.openPicker({
multiple: true,
waitAnimationEnd: false,
}).then(images => {
for (var i=0;i<images.length;i++) {
dataToPost.push({
uri: images[i].path,
width: images[i].width,
height: images[i].height,
mime: images[i].mime,
});
}
this.setState({
images: dataToPost
});
}).catch(e =>
alert(e)
); }else{
ImagePicker.openPicker({
width: 300,
height: 300,
cropping: false,
cropperCircleOverlay: false,
compressImageMaxWidth: 480,
compressImageMaxHeight: 640,
compressImageQuality: 0.5,
mediaType: 'photo',
compressVideoPreset: 'MediumQuality'
}).then(image => {
dataToPost.push({
uri: image.path,
width: image.width,
height: image.height,
mime: image.mime
});
this.setState({
images: dataToPost
});
}).catch(e => {
Alert.alert(e.message
? e.message
: e);
});
}
} renderImage(image) {
return <Image style={{width: 100, height: 100, resizeMode: 'contain'}} source={image} />
} //数据提交
commitPage=()=>{
let formData = new FormData();
if(this.state.images == null){
alert("没有选择图片");
} else {
for(var i = 0;i<this.state.images.length;i++){
var uri = this.state.images[i].uri;
var index = uri.lastIndexOf("\/");
var name = uri.substring(index + 1, uri.length);
let file = {uri: uri, type: 'multipart/form-data', name: name } ;
formData.append('file', file);
}
} //上传图片时,可以在此添加相关其他参数
formData.append('userId', '1');
formData.append('fileType', 'image');
formData.append('name','time');
formData.append('phone', '11222222'); ModalProgress.show("数据上传中,请稍后....");
const REQUEST_URL = Config.domain+'/upload/uploadQualifications';
fetch(REQUEST_URL,{
method:'POST',
headers:{
'Content-Type':'multipart/form-data',
'Accept': 'application/json'
},
body:formData,
}).then((response) => response.json()).then((responseJson) => {
alert(JSON.stringify(responseJson));
if (responseJson.status == 0) {
ModalProgress.hide();
{this.goBack()}
}else{
ModalProgress.hide();
alert(responseJson.msg);
}
}).catch((error) => {
alert(error);
ModalProgress.hide();
}); }
}
image.png作者:Time_二胡
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
004-React-Native--多图选择上传的更多相关文章
- 没有选择上传的文件或选择的文件大小超出大小(DEDECMS亲身试验成功)
dedecms升级到5.7后,后台上传压缩包文件,提示"没有选择上传的文件或选择的文件大小超出大小",由于很久都没弄这个系统了,所以最早怎么设置的也忘记了,就上百度搜,基本上有说的 ...
- Ext.js多文件选择上传,
工作了之后来到了一家用Ext.js的公司, 一开始的时候做项目, 我被分给一个做一个单表的增删改查, 再加上文件上传功能, 带我的老师让我自己研究一下Ext.js怎么多文件选择上传, 并且能获取到上传 ...
- 关于React Native项目在android上UI性能调试实践
我们尽最大的努力来争取使UI组件的性能如丝般顺滑,但有的时候这根本不可能做到.要知道,Android有超过一万种不同型号的手机,而在框架底层进行软件渲染的时候是统一处理的,这意味着你没办法像iOS那样 ...
- SpringMvc+jQuery 文件拖拽上传、选择上传
最近做了个简易的基于boostrap的文件上传功能,jsp版本的,后续会完善更多的功能,不过现在已经能用了,需要的小伙伴,直接引用下面的文件内容直接copy到自己的项目中就ok了,效果如图: file ...
- 帝国CMS7.2新增多图同时上传插件,上传多图效率更高
原来上传多图文件,需要挨个选择文件,然后再点批量上传,比较麻烦.所以帝国CMS7.2新增了多图上传插件:为采用FLASH方式实现同时选择多个图片一起上传,提高多图上传效率. 帝国CMS多图上传插件特性 ...
- Typora图床上传配置:PicGo+Gitee 不完全指南
每次写Markdown都要手动传图,再复制链接到Typora里,这样比较繁琐. 设置好图床,搭配PicGo,写作时直接剪贴图片到Typora,就能实现自动上传,这样就方便很多. Gitee配置: 许多 ...
- js前端实现多图图片上传预览
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="C ...
- 关于阿里ICON矢量图(SVG)上传问题.
注意点: 1. 存储为svg格式(建议使用存储为svg,不要使用导出为svg)2. 图像位置:链接(注意哦,不要点嵌入和保留编辑功能)---确定3. AI里面选中图形,点对象-路径-轮廓化描边 软件编 ...
- React + js-xlsx构建Excel文件上传预览功能
首先要准备react开发环境以及js-xlsx插件 1. 此处省略安装react安装步骤 2.下载js-xlsx插件 yarn add xlsx 或者 npm install xlsx 在项目中引入 ...
随机推荐
- 解决当FORM的ENCTYPE="multipart/form-data" 时request.getParameter()获取不到值的方法
部分转载于: http://blog.csdn.net/georgejin/article/details/1706647 http://www.cnblogs.com/loveyunk/p/6089 ...
- web工程迁移---在一个jboss5或jboss6中运行多个实例
在工作中遇到的,如何在一个jboss中运行多个节点(segment). 我使用的环境是win7.jboss5.jboss6.JDK6 1.jboss5下运行多个实例 第一步不用说,首先要在环境变量中设 ...
- MutationObserver DOM变化的观察
简单的给MutationObserver做个测试及总结笔记. MutationObserver,window上的一个(构造)函数,可以通过其创建的观察者(观察对象)达到观察DOM的变化的效果. 可适用 ...
- 理解 Generator 的执行
Generator & yield 开局官宣:sec-generatoryield,这是对yield的介绍. 同样巴拉巴拉列了9条,将以上链接中的说明简化成3条: 1. 在GeneratorF ...
- java学习-加载.properties工具类
javaWeb项目,要加载xxx.properties或其它如.txt, .md后缀的文本文件 文本内容有两种格式 key:value或者key=value 诸如Spring框架,Jfinal框架,都 ...
- java5新特性-加强for循环
本文目标是加强for循环和普通for循环的比较.阅读本文大概3-5分钟 刚开始学习编程语言的时候接触了三种循环方式 1. for 常用 2. while 较常用 3 do ... while 不常用 ...
- redis学习(六)redis管道
redis管道 1.redis管道介绍 redis采用的是CS架构,客户端与服务器端通过tcp协议进行连接通信,因此无论是发出请求还是接收响应,都必须经过网络传输.在tcp连接过程中,客户端和服务器端 ...
- Tomcat学习总结(5)——Tomcat容器管理安全的几种验证方式
当访问服务器中受保护的资源时,容器管理的验证方法可以控制确认用户身份的方式.Tomcat支持四种容器管理的安全防护,它们是: BASIC (基本验证):通过HTTP验证,需要提供base64编码文本的 ...
- Autowired使用说明
使用了那么久Spring,一下子问我Autowired注解使用条件,答不上来吧,看了Spring源码,一点点收货: 废话少说,要是Autowired生效,需要注册BeanPostProcessor,你 ...
- 【学习笔记】浅析Promise函数
一.Promise是什么? 在JavaScript中,所有的代码都是单线程执行,所以javaScript的所有网络操作(“GET”/"POST"/"PUT"/& ...