Skip to content

JayWii/vue-previewer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

vue-preview-deleter

基于vue2.0的图片预览与删除组件

DEMO

可以自定义删除图片的回调函数,在点击删除图片的操作时,回调函数将根据removeInside的值来返回不同的参数,参数包括操作结果 result 和 具体数据 data

  1. removeInsidetrue 时:data将返回所删元素的索引index,所删元素removeTarget,和删除元素后的列表fileList,此时应在回调函数内将返回的新的数组赋值到imgs上;
  2. removeInsidefalse 时:data将返回所删元素的索引index,所删元素removeTarget,和原始列表fileList,此时应在回调函数内进行删除操作,并重新对imgs赋值;

文档:https://github.com/JayWii/vue-previewer

Install

npm install vue-preview-deleter --save

Usage

// main.js
import VuePreviewer from 'vue-preview-deleter'
Vue.use(VuePreviewer)
<!-- component.vue -->
<template>
  <div id="app">
    <!--一般使用 -->
    <vue-previewer :imgs="imgs" @onRemove="handleRemove" @onClose="closeHandler"></vue-previewer>
    <!--slot引入图片上传元素 -->
    <!--
    <vue-previewer :imgs="imgs" @onRemove="handleRemove" @onClose="closeHandler">
        <div slot="uploader">图片上传元素或其他任意你想插入到图片list尾部的元素</div>
    </vue-previewer> 
    -->
  </div>
</template>

<script>
export default {
  data() {
    return {
      imgs: [
        {
          src: 'https://farm4.staticflickr.com/3894/15008518202_b016d7d289_b.jpg',
          author: 'Folkert Gorter',
          desc: 'This is dummy caption.'
        },
        {
          src: 'https://farm6.staticflickr.com/5584/14985868676_4b802b932a_b.jpg'
        },
        {
          src: 'https://farm4.staticflickr.com/3920/15008465772_383e697089_b.jpg',
          author: 'Folkert Gorter2',
          desc: 'It\'s a dummy caption. He who searches for meaning here will be sorely disappointed.'
        }
      ]
    }
  },
  methods: {
    closeHandler () {
      console.log('cloooooose')
    },
    handleRemove (index, fileList, target) {
      this.imgs = fileList
    }
  }
}
</script>

options

  1. imgs - 图片文件或链接列表,可传入File,url,base64
    • type: Array
    • required : true
  2. width - 每个图片单元的宽高(为保证图片呈现为方形,高度等于宽度),单位是px
    • type: Number
    • required : false
    • default : 80
  3. margin - 每个图片单元的上外边距和右外边距,单位是px
    • type: Number
    • required : false
    • default : 10
  4. radius - 每个图片单元的圆角值,单位是px
    • type: Number
    • required : false
    • default : 5
  5. removeEnable - 是否可进行删除图片操作,假如为false,则点击图片直接查看大图
    • type: Boolean
    • required : false
    • default : true
  6. removeInside - 删除图片的操作实际是在组件外处理还是组件内处理
    • type: Boolean
    • required : false
    • default : true
  7. deleteBtnColor - 删除按钮的颜色
    • type: String
    • required : false
    • default : '#e12e2e'
  8. previewBtnColor - 预览按钮的颜色
    • type: String
    • required : false
    • default : '#3caaff'
  9. type - 传入的列表值类型,分为两个值:fileurl (base64也用url)
    • type: String
    • required : false
    • default : 'url'
  10. srcName - 传入的链接字段名
    • type: String
    • required : false
    • default : 'src'

callBack

  1. onRemove - 删除之后的回调函数
    • type: Function
    • required : false

License

MIT

致谢

vue-picture-preview

About

Vue图片预览与删除插件

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published