ionic开发之用户头像修改-图片选择与上传

简介: 用户头像修改,图片选择上传,非常常用的功能,本来打算和wap版一样,也用XMLHttpRequest和FormData来处理图片异步上传,结果在手机上测试的时候发现,onload事件没有触发,没找到原因,本来想省点事才不用插件去实现这个功能的,这下看来只能用插件了。
用户头像修改,图片选择上传,非常常用的功能,本来打算和wap版一样,也用XMLHttpRequest和FormData来处理图片异步上传,结果在手机上测试的时候发现,onload事件没有触发,没找到原因,本来想省点事才不用插件去实现这个功能的,这下看来只能用插件了。

准备
首先,这里需要用到 Camera File File Transfer 这3个插件。怎么安装自己看官网吧,很容易。

第一步

修改头像的第一步,当然是点击当前界面的头像图片或者其他什么地方,然后弹出一个框,让用户选择是从相册选择图片还是拍照。


$scope.selectImg = function() {
    var hideSheet = $ionicActionSheet.show({
        buttons: [{
                text: '相册'
            }, {
                text: '拍照'
            }
        ],
        titleText: '选择图片',
        cancelText: '取消',
        cancel: function() {
            // add cancel code..
        },
        buttonClicked: function(index) {
            navigator.camera.getPicture(cameraSuccess, cameraError, {
                sourceType: index
            }); //调用系统相册、拍照
        }
    });
}


这里用了ionic的actionsheet,在用户点击按钮的时候,改变sourceType的值,这个参数的作用是决定系统是打开相册还是拍照,刚好0是相册,1是拍照,所以直接sourceType=index,其他的参数看官网说明
在这里,我们还传递了cameraSuccess和cameraError 两个参数,分别是选择照片成功和失败的回调函数。

第二步
在第一步选择照片成功后,我们就需要在回调函数cameraSuccess中处理选择的图片文件,然后上传到服务器。


function cameraSuccess(img) {
        $scope.img = img;//这里返回的img是选择的图片的地址,可以直接赋给img标签的src,就能显示了
        window.resolveLocalFileSystemURL(img, function success(fileEntry) { 
            upload(fileEntry.toInternalURL());//将获取的文件地址转换成file transfer插件需要的绝对地址
        }, function() {
            alert("上传失败");
        });
    }


    function cameraError(img) {
       alert("上传失败");
    }


    function upload(fileURL) {//上传图片
        var win = function(r) {//成功回调方法
            var response = JSON.parse(r.response);//你的上传接口返回的数据
            if(response.datas.state){
                alert("修改成功");
            }else {
                alert(response.datas.error);
            }
        }
        var fail = function(error) {//失败回调方法
            alert("上传失败");
        }


        var options = new FileUploadOptions();
        options.fileKey = "pic";//这是你的上传接口的文件标识,服务器通过这个标识获取文件
        options.fileName = fileURL.substr(fileURL.lastIndexOf('/') + 1);
        options.mimeType = "image/gif";//图片


        var ft = new FileTransfer();
        ft.upload(fileURL, encodeURI('uploadurl'), win, fail, options);//开始上传,uoloadurl是你的上传接口地址
    }


最后
以上是我的图片选择上传方法,测试过可用,其他类型的文件上传也是同理,想要加上进度显示的话,查看官网File Transfer插件的使用。
在安装了以上插件后,惊奇的发现,直接使用之前的异步上传方案,竟然也可以了。。。。好吧,也许就是因为少了其中了某个插件导致之前使用不成功吧。总之,使用以上的方案唯一的好处是多了个拍照的功能

目录
相关文章
ionic3 + springmvc/springboot + angular图片上传以及渲染
ionic3 + springmvc/springboot + angular图片上传以及渲染
133 0
ionic3 + springmvc/springboot + angular图片上传以及渲染
|
JavaScript 前端开发 Android开发
Ionic 开发中遇到的常见问题及解决方案
Ionic 常见问题及解决方案
8374 0
|
Web App开发 索引
Ionic 2 开发(一)_安装与目录结构
由于公司开始使用后ionic 进行前段开发,现在需要学习下ionic,虽然是后台开发,但是还是有必要了解下的 安装Node.js 官网:http://nodejs.cn/ 自行下载安装 安装Ionic npm install -g cordova npm install -g ionic 设置淘宝镜像 npm config set registry https://registry.
1095 0
|
Web App开发 移动开发 JavaScript
Win10 UWP开发系列:使用VS2015 Update2+ionic开发第一个Cordova App
原文:Win10 UWP开发系列:使用VS2015 Update2+ionic开发第一个Cordova App 安装VS2015 Update2的过程是非常曲折的。还好经过不懈的努力,终于折腾成功了。 如果开发Cordova项目的话,推荐大家用一下ionic这个框架,效果还不错。
1791 0
|
缓存 JavaScript Android开发
Ionic 1 & 2 开发常见问题 Q&A
原文发表于我的技术博客 本文分享了在 Ionic 1 & 2 版本开发过程中常见问题的一些 Q&A,供慕课网同学或其他朋友参考。原文发表于我的技术博客 1. 版本的问题 Ionic 2 目前属于快速迭代更新的版本,版本的更新会带来如文件结构和少许代码的变更,不过底层还是构建于 Angular 2 ...
1530 0
|
移动开发 前端开发 JavaScript
【技术干货】前端开发之IONIC移动端开发
Ionic是一套HTML5 Hybrid Mobile应用开发框架,本文给大家介绍的是如何在MAC下搭建Ionic开发平台和开发移动端应用。快点戳进来看看吧~
6001 0
|
前端开发 JavaScript iOS开发
ionic react-native和native开发移动app到底那个好
ionic react-native和native开发移动app那个好 ? 移动端开发如何选型?这里介绍一下我眼中的ionic,react-native,native 三种移动端开发选型对比。欢迎大家补充指正一、 跨平台特性    ionic : write once, run anywhere (...
1203 0
|
JavaScript 开发工具 Python
使用cordova+Ionic+AngularJs进行Hybird App开发的环境搭建手册
一,所需工具       1,JDK:生成     2,安卓SDK开发环境     3,NodeJs:主要使用的还是npm     4,Python开发环境     5,VS 2012(2008,2015也可以,已亲测):安装这个主要是需要一些.net的东西,也没具体查是啥,图个省事。
1481 0
|
移动开发 前端开发 JavaScript
公开课--通过Ionic开发跨终端应用
<p></p> <h1> <span style="font-family:宋体; font-size:22pt">1 <span style="font-family:宋体">现在的</span><span style="font-family:Calibri">app</span><span style="font-family:宋体">开发类型有几种?</span></span><
2497 0