AngularJS之手机端input图片上传

呐,好久不见,今天要说的是input上传图片,主角上场~
<input type="file" capture="camera" accept="image/*">
其实只要type="file"这个属性就够了,但是由于这边是在手机上访问,要能够调起手机的照相机和相册,所以就需要有后面的属性了。

现在如果我已经在相册选择一张图片了,那怎么获取图片数据呢?
传统做法就是加上onchange事件,但是由于使用的是angularjs,按道理应该用ng-change事件,不幸的事,并不触发…实际上onchange是可以触发的,但是并不能找到controller里对应的事件处理方法…
代码里写上 οnchange=“uploadDown()”,controller里也有对应事件,但是报错:
这里写图片
救命…

冥冥之中感觉需要用指令了,在stackoverflow上找到下面这个,就不费脑细胞造轮子啦,哈哈~

app.register.directive('inputOnChange', function(){
  return{
    restrict: 'A',
    link: function (scope, element, attrs) {
      var onChangeFunc = scope.$eval(attrs.inputOnChange);
      element.bind('change', onChangeFunc);
    }
  }
});

下来在input上加上这个属性就ok了:

<input type="file" capture="camera" accept="image/*" input-on-change="uploadDown">

controller里事件:

$scope.uploadDown = function () {
      var file = event.target.files[0].name;
      alert('选择的文件名称:'+file);
    }

以上取到的是文件的名字,很明显,只有文件名可不够哇,有的同学可能需要base64?

h5里有个FileReader对象,可以获取各种信息…
当然用之前最好还是判断下当前浏览器是否支持:

if(type of FileReader === 'undefined'){
	alert('不支持');
}

ok,完善一下uploadDown()事件:

 $scope.uploadDown = function () {
      var file = event.target.files[0];
       //判断类型是不是图片
      if (!/image\/\w+/.test(file.type)) {
        alert("非图片");
        return;
      }
      var reader = new FileReader();
      reader.readAsDataURL(file);
      reader.onload = function (e) {
	      alert(this.result);//base64
      }
    }

顺便说下FileReader的方法:
readAsBinaryString(file) ------ 将文件读取二进制码
readAsText(file,[encoding]) ------ 将文件读取文本(encoding默认UTF-8)
readAsDataURL(file) ------ 将文件读取为DataURL
abort() ------- 中断读取操作

以及FileReader的事件:
onabort ---------数据读取中断时触发
onerror ---------数据读取出错时触发
onloadstart --------数据读取开始时触发
onprocess --------数据读取中
onload --------数据读取成功完成时触发
onloadend --------数据读取完成时触发,无论成功失败

很明显,我这边用的是onload和readAsDataURL(file)
好啦,到目前为止,该取的都取到了,下来就可以用$resource将数据传给后端服务了~

可能有些同学还是不满意,因为当前虽然能获取到所选图片的数据,但是只存在于js端,如果需要给用户预览呢?

   $scope.uploadDown = function () {
      var file = event.target.files[0];
      $scope.imgSrc=window.URL.createObjectURL(file);//这个方法只支持火狐类,手机上没人用IE吧,哈哈哈
    };
 <img src="{{imgSrc}}" style="display: block; width: 200px; height: 150px;">

以上即可。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值