
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
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$(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中。