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 相关文章推荐
jquery 可拖拽的窗体控件实现代码
Mar 21 Javascript
jQuery 表格工具集
Apr 25 Javascript
基于jquery实现后台左侧菜单点击上下滑动显示
Apr 11 Javascript
jQuery+css实现百度百科的页面导航效果
Dec 16 Javascript
angularjs基础教程
Dec 25 Javascript
js记录点击某个按钮的次数-刷新次数为初始状态的实例
Feb 15 Javascript
AngularJS修改model值时,显示内容不变的实例
Sep 13 Javascript
jQuery使用bind动态绑定事件无效的处理方法
Dec 11 jQuery
浅谈Vue中render中的h箭头函数
Nov 07 Javascript
js代码实现轮播图
May 04 Javascript
Vue的Options用法说明
Aug 14 Javascript
vue+elementui 实现新增和修改共用一个弹框的完整代码
Jun 08 Vue.js
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
《被神捡到的男人》动画化计划进行中!
2020/03/06 日漫
星际争霸 Starcraft 发展史
2020/03/14 星际争霸
global.php
2006/12/09 PHP
php文件上传原理与实现方法详解
2019/12/20 PHP
有关DOM元素与事件的3个谜题
2010/11/11 Javascript
js控制的回到页面顶端goTop的代码实现
2013/03/20 Javascript
JS,Jquery获取select,dropdownlist,checkbox下拉列表框的值(示例代码)
2014/01/11 Javascript
js动态创建标签示例代码
2014/06/09 Javascript
JavaScript中String.prototype用法实例
2015/05/20 Javascript
javascript实现支持移动设备画廊
2015/08/24 Javascript
JS实现回到页面顶部动画效果的简单实例
2016/05/24 Javascript
再次谈论Javascript中的this
2016/06/23 Javascript
jQuery对checkbox 复选框的全选全不选反选的操作
2016/08/09 Javascript
浅谈js函数中的实例对象、类对象、局部变量(局部函数)
2016/11/20 Javascript
微信小程序 利用css实现遮罩效果实例详解
2017/01/21 Javascript
flag和jq on 的绑定多个对象和方法(必看)
2017/02/27 Javascript
基于vue实现分页/翻页组件paginator示例
2017/03/09 Javascript
Vue 过渡实现轮播图效果
2017/03/27 Javascript
浅谈React中组件间抽象
2018/01/27 Javascript
JavaScript常用工具函数大全
2020/05/06 Javascript
vue动态加载SVG文件并修改节点数据的操作代码
2020/08/17 Javascript
Javascript类型判断相关例题及解析
2020/08/26 Javascript
基于Django contrib Comments 评论模块(详解)
2017/12/08 Python
Anaconda下安装mysql-python的包实例
2018/06/11 Python
Python列表(List)知识点总结
2019/02/18 Python
python项目对接钉钉SDK的实现
2019/07/15 Python
Django CBV类的用法详解
2019/07/26 Python
使用python-pptx包批量修改ppt格式的实现
2020/02/14 Python
Python实现PS滤镜中的USM锐化效果
2020/12/04 Python
纯CSS3实现自定义Tooltip边框涂鸦风格的教程
2014/11/05 HTML / CSS
遗嘱继承权公证书
2015/01/26 职场文书
2015纪念九一八事变84周年演讲稿
2015/03/19 职场文书
2019让人心动的商业计划书
2019/06/27 职场文书
聊聊Python中关于a=[[]]*3的反思
2021/06/02 Python
sql字段解析器的实现示例
2021/06/23 SQL Server
基于MySql验证的vsftpd虚拟用户
2021/11/07 MySQL