jQuery实现图片上传和裁剪插件Croppie


Posted in Javascript onNovember 29, 2015

在很多应用需要上传本地图片然后再按尺寸适当裁剪以符合网站对图片尺寸的要求。最常见的就是各用户系统要求用户上传和裁剪头像的应用。今天我给大家介绍的是一款基于HTML5和jQuery的图片上传和裁剪插件,它叫Croppie。

运行效果图:

jQuery实现图片上传和裁剪插件Croppie

HTML
首先我们将相关js和css文件载入head中。

<script src="jquery.min.js"></script> 
<script src="croppie.min.js"></script> 
<link rel="stylesheet" href="croppie.css">

接下来我们在页面上放置一个图片上传按钮,我们可以用css将type="file"的文件选择控件转成按钮样式。选择完图片后,在#upload-demo展示上传图片,以及调用裁剪插件Croppie。#result用来展示裁剪后的图片。

<div class="actions"> 
 <button class="file-btn"> 
  <span>上传</span> 
  <input type="file" id="upload" value="选择图片文件" /> 
 </button> 
 <div class="crop"> 
  <div id="upload-demo"></div> 
  <button class="upload-result">裁剪</button> 
 </div> 
 <div id="result"></div> 
</div>

CSS
使用以下CSS代码,我们很完美的将选择文件的控件转成按钮的样式,其实就是将type="file"透明度设成0,然后和button重叠。此外,我们先将图片裁剪区域.crop设置为不可见,等选择文件后再显示。

button, 
a.btn { 
 background-color: #189094; 
 color: white; 
 padding: 10px 15px; 
 border-radius: 3px; 
 border: 1px solid rgba(255, 255, 255, 0.5); 
 font-size: 16px; 
 cursor: pointer; 
 text-decoration: none; 
 text-shadow: none; 
} 
button:focus { 
 outline: 0; 
} 
 
.file-btn { 
 position: relative; 
} 
.file-btn input[type="file"] { 
 position: absolute; 
 top: 0; 
 left: 0; 
 width: 100%; 
 height: 100%; 
 opacity: 0; 
} 
 
.actions { 
 padding: 5px 0; 
} 
.actions button { 
 margin-right: 5px; 
} 
.crop{display:none}

jQuery
首先利用HTML5的FileReader API读取本地文件,然后$('#upload-demo').croppie()调用了Croppie插件。Croppie的选项viewport:可以设置所裁剪图片的宽度和高度,以及类型(圆形或方形);选项boundary是图片的外围尺寸。它还有参数mouseWheelZoom:是否支持鼠标滚轮缩放图像;showZoom:是否展示缩放条工具;update:回调函数。

$(function(){ 
 var $uploadCrop; 
 
  function readFile(input) { 
    if (input.files && input.files[0]) { 
    var reader = new FileReader(); 
     
    reader.onload = function (e) { 
     $uploadCrop.croppie('bind', { 
      url: e.target.result 
     }); 
    } 
     
    reader.readAsDataURL(input.files[0]); 
   } 
   else { 
    alert("Sorry - you're browser doesn't support the FileReader API"); 
   } 
  } 
 
  $uploadCrop = $('#upload-demo').croppie({ 
   viewport: { 
    width: 200, 
    height: 200, 
    type: 'circle' 
   }, 
   boundary: { 
    width: 300, 
    height: 300 
   } 
  }); 
 
  $('#upload').on('change', function () { 
   $(".crop").show(); 
   readFile(this); 
  }); 
  $('.upload-result').on('click', function (ev) { 
   $uploadCrop.croppie('result', 'canvas').then(function (resp) { 
    popupResult({ 
     src: resp 
    }); 
   }); 
  }); 
   
 function popupResult(result) { 
  var html; 
  if (result.html) { 
   html = result.html; 
  } 
  if (result.src) { 
   html = '<img src="' + result.src + '" />'; 
  } 
  $("#result").html(html); 
 } 
});

当点击“裁剪”按钮后,再次调用Croppie的result的方法,返回一张裁剪后的图片,并显示在#result中。

更多精彩内容请参考专题《ajax上传技术汇总》,《javascript文件上传操作汇总》和《jQuery上传操作汇总》进行学习。

以上就是jQuery实现图片上传和裁剪的主要过程,希望对大家学习图片上传和裁剪技术有所帮助。

Javascript 相关文章推荐
tagName的使用,留一笔
Jun 26 Javascript
使用UglifyJS合并/压缩JavaScript的方法
Mar 07 Javascript
javascript中input中readonly和disabled区别介绍
Oct 23 Javascript
JQuery事件e参数的方法preventDefault()取消默认行为
Sep 26 Javascript
谈谈JavaScript中function多重理解
Aug 28 Javascript
JavaScript兼容浏览器FF/IE技巧
Aug 14 Javascript
jQuery中的insertBefore(),insertAfter(),after(),before()区别介绍
Sep 01 Javascript
JS原型链 详解及示例代码
Sep 06 Javascript
AngularJS ng-repeat数组有重复值的解决方法
Oct 23 Javascript
js实现文字选中分享功能
Jan 25 Javascript
javascript和php使用ajax通信传递JSON的实例
Aug 21 Javascript
浅析Vue.js中v-bind v-model的使用和区别
Dec 04 Javascript
javascript高级编程之函数表达式 递归和闭包函数
Nov 29 #Javascript
javascript实现拖动元素交换位置
Nov 29 #Javascript
javascript实现网页中涉及的简易运动(改变宽高、透明度、位置)
Nov 29 #Javascript
通用javascript代码判断版本号是否在版本范围之间
Nov 29 #Javascript
jQuery如何使用自动触发事件trigger
Nov 29 #Javascript
js性能优化技巧
Nov 29 #Javascript
javascript实现C语言经典程序题
Nov 29 #Javascript
You might like
一步一步学习PHP(4) php 函数 补充2
2010/02/15 PHP
PHP无限分类(树形类)的深入分析
2013/06/02 PHP
php生成年月日下载列表的方法
2015/04/24 PHP
PHP Hash算法:Times33算法代码实例
2015/05/13 PHP
PHP中array_keys和array_unique函数源码的分析
2016/02/26 PHP
laravel 解决paginate查询多个字段报错的问题
2019/10/22 PHP
javascript getElementsByName()的用法说明
2009/07/31 Javascript
基于jquery的网站幻灯片切换效果焦点图代码
2013/09/15 Javascript
javascript模拟post提交隐藏地址栏的参数
2014/09/03 Javascript
高性能JavaScript模板引擎实现原理详解
2015/02/05 Javascript
JavaScript中使用Math.PI圆周率属性的方法
2015/06/14 Javascript
Atitit.js的键盘按键事件捆绑and事件调度
2016/04/01 Javascript
详解jQuery中的empty、remove和detach
2016/04/11 Javascript
vuejs动态组件给子组件传递数据的方法详解
2016/09/09 Javascript
基于JavaScript实现随机颜色输入框
2016/12/10 Javascript
Restify中接入Socket.io报Error:Can’t set headers的错误解决
2017/03/28 Javascript
为JQuery EasyUI 表单组件增加焦点切换功能的方法
2017/04/13 jQuery
JavaScript生成图形验证码
2020/08/24 Javascript
JS正则表达式常见函数与用法小结
2020/04/13 Javascript
OpenLayers3实现测量功能
2020/09/25 Javascript
Python的多态性实例分析
2015/07/07 Python
Scrapy爬虫实例讲解_校花网
2017/10/23 Python
python清除函数占用的内存方法
2018/06/25 Python
Python实现矩阵相乘的三种方法小结
2018/07/26 Python
python实现WebSocket服务端过程解析
2019/10/18 Python
python学习笔记之多进程
2020/08/06 Python
Django日志及中间件模块应用案例
2020/09/10 Python
python批量合成bilibili的m4s缓存文件为MP4格式 ver2.5
2020/12/01 Python
实例教程 利用html5和css3打造一款创意404页面
2014/10/20 HTML / CSS
新西兰第一的行李箱网站:luggage.co.nz
2019/07/22 全球购物
应届实习生的自我评价范文
2014/01/05 职场文书
卖车协议书
2014/04/21 职场文书
迎国庆演讲稿
2014/09/15 职场文书
国际残疾人日广播稿范文
2014/10/09 职场文书
党员干部三严三实心得体会
2014/10/13 职场文书
广告业务员岗位职责
2015/02/13 职场文书