vue-image-crop基于Vue的移动端图片裁剪组件示例

前端之家收集整理的这篇文章主要介绍了vue-image-crop基于Vue的移动端图片裁剪组件示例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文介绍了vue-image-crop基于Vue的移动端图片裁剪组件示例,分享给大家,具体如下:

代码地址:https://github.com/jczzq/vue-image-crop

vue-image-crop

基于Vue的移动端图片裁剪组件

组件使用URL.createObjectURL()等新特性,使用前注意兼容问题。IE >= 10

注意:该组件适用于 PC 端,不推荐手机端使用。

功能预览

快速开始

安装Node >= 8.9.0(推荐LTS = 8.11.0

cd vue-image-crop
npm install
npm run dev

启动开发模式即可定制功能

构建

build之后会重新生成lib文件

API

props

属性图片对象;必传;可使用v-model绑定图片宽高比例对象;非必传;用于动态计算宽高比例,所以w和h两个属性没有固定值HTMLCanvasElement.toDataURL()的第二个参数显示移除按钮;非必传;列表中使用时可能会用到上传;非必传;设置为true的时候图片将不会裁剪直接返回属性都必须传;size:图片最大宽度(px),isSlice:是否需要裁剪,path:显示图片时的路径,path参数将直接与图片id拼接(path + id)

events

事件名

图片时触发文件图片操作完成时触发图片对象图片操作取消时触发

示例代码

常规用法

<p>调整比例</p>
<m-image-crop class="mic mic2"
       v-model="img2"
       :proportion="{ w: 100,h: 35 }"&gt;</m-image-crop>

<p>列表</p>
<div class="list"&gt;
  <div class="item"
     v-for="(item,index) in imgList"
     :key="item.id"&gt;
    <m-image-crop class="mic"
           has-remove
           :value="item"
           :proportion="{ w: 1,h: 1 }"
           @remove="removeHandle(index)"&gt;</m-image-crop>
  </div>
  <div class="item add"
     @click="addHandle"&gt;<a href="/tag/tianjia/" target="_blank" class="keywords">添加</a><a href="/tag/tupian/" target="_blank" class="keywords">图片</a></div>
</div>

<style lang="less">
html,body {
margin: 0;
}
.ctnr {
height: 100vh;
.mic {
border: 1px dotted #4fc08d;
}
.mic1 {
width: 200px;
height: 100px;
}
.mic2 {
width: 100vw;
height: 35vw;
}
.list {
font-size: 0;
.item {
Box-sizing: border-Box;
font-size: 14px;
vertical-align: middle;
display: inline-block;
border: 1px dotted #4fc08d;
width: 33.33vw;
height: 33.33vw;
}
.add {
text-align: center;
line-height: 33.33vw;
}
}
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

猜你在找的Vue相关文章

类型 默认值 说明
说明 回调参数