js实现获取手机相册并上传

时间: 2018-08-21阅读: 3241标签: js知识

在写易沃克项目时,一直苦于无路去实现将图片上传至服务器 。这是我的解决方案 
当初有很多人说使用form方法将文件封装来上传,可是因为要照顾到从相机中选择图片,所以一直没有去做。 后来看到了Uploader的方法来传文件,感觉自己找到了 。他是使用plus.uploader来完成的


创建网络上传任务

function createUploader() {
    task = plus.uploader.createUpload(url, {
        method: 'POST'
    }, function(data, status) {
        if(status == 200) {
            plus.nativeUI.closeWaiting();
            var page = plus.webview.getWebviewById('view/dynamics/dynamics.html');
            mui.fire(page, 'refresh', {});
            mui.openWindow({
                id: 'index.html'
            });
        } else {
            mui.alert(status);
        }
    });

}


相机拍照并获取到图片


//从相机中选取图片
function clickCamera() {
    var c = plus.camera.getCamera();
    c.captureImage(function(e) {
        plus.io.resolveLocalFileSystemURL(e, function(entry) {

            var path = entry.toLocalURL();
            var name = name = path.substr(e.lastIndexOf('/') + 1);

            //压缩图片到内存
            plus.zip.compressImage({
                src: path,
                dst: '_doc/' + path,
                quality: 20,
                overwrite: true
            }, function(zip) {
                camera_photos.push({
                    path: zip.target
                });
                photos.push({
                    path: zip.target
                });
                showPhotos();
            }, function(error) {
                console.log("压缩error");
            });

        }, function(e) {
            mui.toast("读取拍照文件错误" + e.message);
        });
    })
};


获取手机相册,并为多选

var max = 9; //照片的最大数目
var galleryPhotoNum;
var galleryFiles;

function clickGallery() {
    //确定还可以从相册中选择照片的最大数目  
    galleryPhotoNum = max - camera_photos.length;
    plus.gallery.pick(function(path) {
        galleryFiles = path.files;
        plus.nativeUI.showWaiting();
        compressImg(galleryFiles, 0);
    }, function(e) {
        console.log("获取照片失败");
    }, {
        filter: "image",
        multiple: true,
        maximum: galleryPhotoNum,
        system: false,
        onmaxed: function() {
            mui.toast('最多选' + galleryPhotoNum + '个');
        },
        popover: true,
        selected: galleryFiles
    });
}


同时获取到多张图片那么图片的压缩便成了问题 ,我使用的是plus.zip.compressImage()来做,但是如果通过一个for循环来对图片进行压缩是无法完成的 。
因为for循环速度很快,而plus.zip.compressImg是异步执行的,而且手机执行的压缩方法是有限制的,3个,超过就直接不执行了。所以我们要保证当一张压缩成功之后,再执行下一张, 通过递归来保证

//递归压缩图片
function compressImg(files, file_index) {
    var file_length = files.length;
    var path = files[file_index];
    plus.zip.compressImage({
        src: path,
        dst: '_doc/' + path,
        quality: 20,
        overwrite: true
    }, function(zip) {
        var next_file_index = file_index + 1;
        if(file_index == 0) {
            gallery_photos = [];
        }
        gallery_photos.push({
            path: zip.target
        });
        addPhoto(zip.target, file_index);
        if(next_file_index < file_length) {
            compressImg(files, next_file_index);
        } else {
            showPhotos();
        }
    })
}

有点不对,好像有点跑题

继续前面提的文件上传, 上面我们新建了文件上传对象task 
如果我们想传值,task.addData(‘name’,value); 
如果想传文件,task.addFile(path,{ key:file.name }); 
当所需要上传的值,都加入之后,便可以使用task.start(); 

来开始所有任务了

task.addData('objectID', this_phoneNum);
    task.addData('describe', content);
    task.addData('position', "");
    task.addData('num', '' + len);
    for(var i = 0; i < len; i++) {
        var j = i + 1;
        var temp = 'phone' + j;
        task.addFile(photos[i].path, {
            key: temp
        });
    }
    task.start();


来源:https://blog.csdn.net/qq_32635069/article/details/72869100

站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: http://www.fly63.com/article/detial/1024

JavaScript中“javascript:void(0) ”是什么意思

expression 是一个要计算的 Javascript 标准的表达式。表达式外侧的圆括号是可选的,鉴于规范化,以及养成好习惯,建议写上去。当我们使用 void 操作符指定超级链接时,表达式会被计算但是不会在当前文档处装入任何内容。

原生js判断当前页面是否为激活状态【判断用户是否在浏览当前页面】

但浏览器打开多个网页时候,如何判断我这个页面是否正在被用户浏览呢?我们可以通过document.hidden属性判断当前页面是否是激活状态。

javascript的Object. hasOwnProperty方法

hasOwnProperty() 方法会返回一个布尔值,指示对象自身属性中(非继承属性)是否具有指定的属性,如果 object 具有带指定名称的属性,则 hasOwnProperty 方法返回 true,否则返回 false。

前端与编译原理——用JS写一个JS解释器

说起编译原理,印象往往只停留在本科时那些枯燥的课程和晦涩的概念。作为前端开发者,编译原理似乎离我们很远,对它的理解很可能仅仅局限于“抽象语法树(AST)”。但这仅仅是个开头而已。编译原理的使用,甚至能让我们利用JS直接写一个能运行JS代码的解释器。

Js输出方式有哪些?

在编写JavaScript代码的时候, 一定要记住每一句代码后面都需要添加一个分号, 并且这个分号必须是英文的分号,我们会发现有时候不写分号程序也能够运行, 这里并不是因为不需要分号, 而是浏览器自动帮助我们添加了分号

JavaScript中的特殊运算,一些有趣的js等式

JavaScript中的特殊运算,字符,true,false参与运算结果会怎么样?打开控制台。这会允许你再你的浏览器里输入下面所有的代码,所以你可以实时的看到发生什么了。

js的解析的两个阶段_预解析阶段、执行阶段

js不像C语言那样只要编译一次之后成.exe文件之后就不用在编译可以直接使用了,js是一种解释型语言,js同理是边解析边执行。js的解析分为两个阶段 1.预解析阶段 2.执行阶段。

你所忽略的js隐式转换

你有没有在面试中遇到特别奇葩的js隐形转换的面试题,第一反应是怎么会是这样呢?难以自信,js到底是怎么去计算得到结果,你是否有深入去了解其原理呢?下面将深入讲解其实现原理。

Js继承实现小结:JavaScript实现继承的6种方式

JS作为面向对象的弱类型语言,继承也是其非常强大的特性之一。那么如何在JS中实现继承呢?1、原型链继承,2、构造继承,3、实例继承,4、拷贝继承,5、组合继承,6、寄生组合继承

javascript:void(0)的含义

首先,void关键字是javascript当中非常重要的关键字,该操作符指定要计算或运行一个表达式,但是不返回值。语法格式:void func()、void(func())

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!