全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

vuejs开发组件分享之H5图片上传、压缩及拍照旋转的问题处理

一、前言

  三年.net开发转前端已经四个月了,前端主要用webpack+vue,由于后端转过来的,前端不够系统,希望分享下开发心得与园友一起学习。

  图片的上传之前都是用的插件(ajaxupload),或者传统上传图片的方式,各有利弊:插件的问题是依赖jq并且会使系统比较臃肿,还有传统的web开发模式 前后端偶尔在一起及对用户体验要求低,现在公司采用webpack+vue+restfullApi开发模式 前后端完全分离,遵从高内聚,低偶尔的原则,开发人员各司其职,一则提升开发效率(从长期来看,短期对于很多开发人员需要有个适应的过程,特别是初中级的前端处理业务逻辑方面的能力比较欠缺),二则提升用户体验。今天分享下在项目开发中写的的图片上传 vue组件。

二、处理问题

  这里用h5做图片上传考虑到浏览器支持的问题,这里考虑的场景是在做webapp的时候

  1.移动web图片上传还包括拍摄上传,但是在移动端会出现拍摄的照片会旋转,处理这个问题需要得到图片旋转的情况,可以用exif.js来获取,具体可以参看文档

  2.图片压缩

  3.旋转

三、代码

1组件代码

<template>
 <div>
  <input type="file" style="display: none;" id="img-upload" multiple accept="image/*" @change="uploadImg($event)"/>
 </div>
</template>
<script>
 import EXIF from '../../../Resource/Global/Js/exif'
 export default{
  name:"image-html5-upload",
  props:{
   imgArr:{
    type:Array,
    twoWay: true,
    default:Array
   },
   imgNumLimit:{//一次最多可以上传多少张照片
    type:Number,
    default:4
   }
  },
  methods:{
   "uploadImg": function(e){
    let tag = e.target;
    let fileList = tag.files;
    let imgNum = fileList.length;
    let _this = this;
    _this.imgArr = [];//图片数据清零
    if(this.imgArr.length + imgNum > this.imgNumLimit){
     alert('一次最多上传'+this.imgNumLimit+'张图片!');
     return;
    }
    var Orientation;
    for(let i=0;i<imgNum;i++){
     EXIF.getData(fileList[i], function(){
      Orientation = EXIF.getTag(fileList[i], 'Orientation');
     });
     let reader = new FileReader();
     reader.readAsDataURL(fileList[i]);
     reader.onload = function(){
      var oReader = new FileReader();
      oReader.onload = function(e) {
       var image = new Image();
       image.src = e.target.result;
       image.onload = function() {
        var expectWidth = this.naturalWidth;
        var expectHeight = this.naturalHeight;
        if (this.naturalWidth > this.naturalHeight && this.naturalWidth > 800) {
         expectWidth = 800;
         expectHeight = expectWidth * this.naturalHeight / this.naturalWidth;
        } else if (this.naturalHeight > this.naturalWidth && this.naturalHeight > 1200) {
         expectHeight = 1200;
         expectWidth = expectHeight * this.naturalWidth / this.naturalHeight;
        }
        var canvas = document.createElement("canvas");
        var ctx = canvas.getContext("2d");
        canvas.width = expectWidth;
        canvas.height = expectHeight;
        ctx.drawImage(this, 0, 0, expectWidth, expectHeight);
        var base64 = null;
        //修复ios上传图片的时候 被旋转的问题
        if(Orientation != "" && Orientation != 1){
         switch(Orientation){
          case 6://需要顺时针(向左)90度旋转
           _this.rotateImg(this,'left',canvas);
           break;
          case 8://需要逆时针(向右)90度旋转
           _this.rotateImg(this,'right',canvas);
           break;
          case 3://需要180度旋转
           _this.rotateImg(this,'right',canvas);//转两次
           _this.rotateImg(this,'right',canvas);
           break;
         }
        }
        base64 = canvas.toDataURL("image/jpeg", 0.8);
        if(fileList[i].size / 1024000 > 1){
         _this.imgScale(base64, 4)
        }else{
         _this.imgArr.push({"src": base64});
        }
        console.log(JSON.stringify(_this.imgArr));
       };
      };
      oReader.readAsDataURL(fileList[i]);
     }
    }
   },
   "imgScale": function(imgUrl,quality){
    let img = new Image();
    let _this = this;
    let canvas = document.createElement('canvas');
    let cxt = canvas.getContext('2d');
    img.src = imgUrl;
    img.onload = function(){
     //缩放后图片的宽高
     let width = img.naturalWidth/quality;
     let height = img.naturalHeight/quality;
     canvas.width = width;
     canvas.height = height;
     cxt.drawImage(this, 0, 0, width, height);
     _this.imgArr.push({"src": canvas.toDataURL('image/jpeg')});
    }
   },
   "rotateImg":function (img, direction,canvas) {//图片旋转
    var min_step = 0;
    var max_step = 3;
    if (img == null)return;
    var height = img.height;
    var width = img.width;
    var step = 2;
    if (step == null) {
     step = min_step;
    }
    if (direction == 'right') {
     step++;
     step > max_step && (step = min_step);
    } else {
     step--;
     step < min_step && (step = max_step);
    }
    var degree = step * 90 * Math.PI / 180;
    var ctx = canvas.getContext('2d');
    switch (step) {
     case 0:
      canvas.width = width;
      canvas.height = height;
      ctx.drawImage(img, 0, 0);
      break;
     case 1:
      canvas.width = height;
      canvas.height = width;
      ctx.rotate(degree);
      ctx.drawImage(img, 0, -height);
      break;
     case 2:
      canvas.width = width;
      canvas.height = height;
      ctx.rotate(degree);
      ctx.drawImage(img, -width, -height);
      break;
     case 3:
      canvas.width = height;
      canvas.height = width;
      ctx.rotate(degree);
      ctx.drawImage(img, -width, 0);
      break;
    }
   }
  }
 }
</script>

2.使用方法

<template>
 <div>
  <div class="album-img-list">
   <ul>
    <li v-for="img in imgList"><div class="album-bg-img"><img :src='img.src'> </div></li>
   </ul>
  </div>
  <div class="album">
   <label for="img-upload">上传照片</label>
    <image-html5-upload :img-arr.sync="imgList"></image-html5-upload>
  </div>
 </div>
</template>

以上所述是小编给大家介绍的vuejs开发组件分享之H5图片上传、压缩及拍照旋转的问题处理,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# vue  # 组件开发  # h5  # 拍照上传  # Vue2.0实现调用摄像头进行拍照功能 exif.js实现图片上传功能  # Vue.js 2.0 移动端拍照压缩图片预览及上传实例  # vue2实现移动端上传、预览、压缩图片解决拍照旋转问题  # Vue.js 2.0 移动端拍照压缩图片上传预览功能  # Vue调用PC摄像头实现拍照功能  # vue调取电脑摄像头实现拍照功能  # vue调用本地摄像头实现拍照功能  # vue实现pc端拍照上传功能  # 图片上传  # 上传  # 最多  # 后端  # 开发人员  # 小编  # 上传图片  # 都是  # 是在  # 有个  # 在此  # 各司其职  # 可以用  # 两次  # 给大家  # 问题是  # 考虑到  # 各有  # 会使  # 所述 


相关文章: 建站之星免费模板:自助建站系统与智能响应式一键生成  如何在香港免费服务器上快速搭建网站?  教程网站设计制作软件,怎么创建自己的一个网站?  模具网站制作流程,如何找模具客户?  佛山企业网站制作公司有哪些,沟通100网上服务官网?  单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?  太平洋网站制作公司,网络用语太平洋是什么意思?  建站主机数据库如何配置才能提升网站性能?  建站之星后台管理如何实现高效配置?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  如何解决VPS建站LNMP环境配置常见问题?  建站之家VIP精选网站模板与SEO优化教程整合指南  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  如何通过山东自助建站平台快速注册域名?  建站主机默认首页配置指南:核心功能与访问路径优化  Python如何创建带属性的XML节点  网站图片在线制作软件,怎么在图片上做链接?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  南平网站制作公司,2025年南平市事业单位报名时间?  建站之星展会模版如何一键下载生成?  昆明高端网站制作公司,昆明公租房申请网上登录入口?  如何通过老薛主机一键快速建站?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  小说建站VPS选用指南:性能对比、配置优化与建站方案解析  网站好制作吗知乎,网站开发好学吗?有什么技巧?  详解jQuery停止动画——stop()方法的使用  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  制作农业网站的软件,比较好的农业网站推荐一下?  合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?  如何快速搭建高效WAP手机网站?  如何在Windows 2008云服务器安全搭建网站?  建站VPS能否同时实现高效与安全翻墙?  C#如何使用XPathNavigator高效查询XML  如何在Golang中指定模块版本_使用go.mod控制版本号  如何通过WDCP绑定主域名及创建子域名站点?  设计网站制作公司有哪些,制作网页教程?  建站主机选虚拟主机还是云服务器更好?  新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?  如何制作网站标识牌,动态网站如何制作(教程)?  广州建站公司哪家好?十大优质服务商推荐  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  javascript基本数据类型及类型检测常用方法小结  高防服务器如何保障网站安全无虞?  建站之星×万网:智能建站系统+自助建站平台一键生成  ,在苏州找工作,上哪个网站比较好?  大连网站设计制作招聘信息,大连投诉网站有哪些?  宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?  公司门户网站制作流程,华为官网怎么做?  建站之星如何保障用户数据免受黑客入侵? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。