vue自定义组件封装_vue组件的双向绑定实现

vue自定义组件封装_vue组件的双向绑定实现vue组件封装,vueelementui组件封装,vue图片上传,elementui图片上传

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

封装组件的v-model

再看组件的时候,不如elementui等等,我们时常看到它们的组件都是直接通过v-model双向绑定的,而不是通过我们常用的属性(prop)传递过去,子组件修改通过$emit,或者通过vuex等等来返回父组件,这样的方法也不是说不行,但是总感觉没有elementui那样的写法高级。所以我们也来简单的封装一个看起来高级一点点的组件。
简单的借用elementui的组件做一个二开

<template>
  <div class="image-video-upload">
    <div v-if="imageUrl" class="upload-success">
      <custom-image :src="imageUrl" class="result-image" :style="imageStyle" />
      <i v-if="!disabled" class="el-icon-circle-close" @click="handleRemove" />
    </div>
    <el-upload
      v-show="!imageUrl"
      ref="uploader"
      class="uploader"
      :action="action"
      :disabled="disabled"
      :headers="headers"
      :accept="accept"
      :show-file-list="false"
      :on-success="handlerSuccess"
      :on-error="handlerError"
      :before-upload="beforeUploadHandler"
      :style="imageStyle"
      :on-progress="handleProcess"
      :data="uploadData"
    >
      <el-progress v-if="uploading" type="circle" :percentage="percentage" :width="80" />
      <i v-else class="el-icon-plus" />
    </el-upload>
    <div class="el-upload__tip" v-html="tip" />
  </div>
</template>
export default { 
   
  name: 'UploadImage',
  components: { 
   
    CustomImage
  },
  props: { 
   
  //v-model直接使用value
    value: { 
   
      type: String,
      default: ''
    },
    bucket: { 
   
      type: String,
      default: 'knight-dev'
    },
    tip: { 
   
      type: String,
      default: ''
    },
    // 控制图片样式(长宽等)
    imageStyle: { 
   
      type: String,
      default: 'width: 200px;height: 100px;'
    },
    accept: { 
   
      type: String,
      default: '.jpg,.jpeg,.png,.gif,.bmp,.JPG,.JPEG,.PBG,.GIF,.BMP'
    },
    width: { 
   
      type: Number,
      default: 0
    },
    height: { 
   
      type: Number,
      default: 0
    },
    // 图片尺寸验证类型
    validType: { 
   
      type: Number,
      default: 0 // 0:比列验证,1:实际大小验证
    },
    // 图片尺寸验证
    valid: { 
   
      type: Number,
      default: 0 // 0: 不验证,不提示 1:验证提示,不停止上传 2: 验证提示,停止上传
    },
    // 图片大小验证,单位M
    imageSize: { 
   
      type: Number,
      default: 3
    },
    disabled: { 
   
      type: Boolean,
      default: false
    }
  },
  data() { 
   
    return { 
   
      uploading: false,
      percentage: 0,
      imageUrl: this.value ? downloadUrl + '/' + this.value : '',
      action: uploadUrl
    }
  },
  computed: { 
   
    uploadData() { 
   
      return { 
    bucket: this.bucket }
    },
    headers() { 
   
      const header = { 
   }
      const { 
    access_token,  login_name } = this.$store.getters.authInfo
      header['Authorization'] = 'Bearer ' + access_token
      
      return header
    }
  },
  watch: { 
   
    value(value) { 
   
      this.imageUrl = value ? downloadUrl + '/' + value : ''
    }
  },
  methods: { 
   
    handleProcess(event, file, fileList) { 
   
      this.percentage = +file.percentage.toFixed(0)
    },
    beforeUploadHandler(file) { 
   
      this.uploading = true
      this.percentage = 0
      const fileSize = file.size / 1024 / 1024
      if (fileSize > this.imageSize) { 
   
        this.uploading = false
        this.$message.error(`图片文件大小不能超过 ${ 
     this.imageSize}MB!`)
        return false
      } else if (this.valid == 0 || this.width == 0 || this.height == 0) { 
   
        return true
      }

      return new Promise((resolve, reject) => { 
   
        this.filetoDataURL(file, url => { 
   
          this.dataURLtoImage(url, img => { 
   
            const { 
    width, height } = this

            let validTemp = true
            let str = ''
            if (this.validType == 0) { 
   
              validTemp =
                  (width / height).toFixed(2) ==
                  (img.width / img.height).toFixed(2)
              str = '比例'
            } else { 
   
              validTemp = width == img.width && height == img.height
              str = '宽高'
            }
            if (!validTemp) { 
   
              this.$message.error(`图片${ 
     str}不符合建议要求!`)
              if (this.valid == 2) { 
   
                this.uploading = false
                return reject()
              }
            }
            resolve()
          })
        })
      })
    },
    handlerSuccess(res) { 
   
      if (res.code == 200) { 
   
        const imageUrl = res.data.fileName[0]
        this.uploading = false
        this.setValue(imageUrl)
      }
    },
    handlerError() { 
   
      this.uploading = false
    },
    setValue(imageUrl) { 
   
      this.imageUrl = imageUrl
      //返回值直接使用$emit('input','value')即可
      this.$emit('input', imageUrl)
    },
    handleRemove() { 
   
      this.setValue('')
    }
  }
}
.image-video-upload { 
   
  display: flex; .uploader, .result-image { 
   
    display: flex;
    font-size: 28px;
    color: #8c939d;
    text-align: center;
    background-color: #fbfdff;
    border: 1px dashed #c0ccda;
    border-radius: 6px;
    cursor: pointer;
  }

  .result-image { 
   
    border: 1px solid #c0ccda;
  }

  .uploader{ 
   
    &:hover { 
   
      border-color: #409eff;
      color: #409eff;
    }

    ::v-deep { 
   
      .el-upload{ 
   
        width: 100%;
        height: 100%;
        display: flex;
        justify-content: center;
        align-items: center; &:focus{ 
   
          border-color: #fbfdff;
          color: #8c939d;
        }

        &:hover{ 
   
          border-color: #409eff;
          color: #409eff;
        }
      }
    }
  }

  .el-upload__tip { 
   
    flex: 1;
    line-height: 21px;
    display: flex;
    align-items: center;
    margin-left: 20px;
    margin-top: 0;
  }

  .upload-success { 
   
    position: relative;
    border-radius: 6px;
    overflow: hidden; &:hover { 
   
      .icon-success { 
   
        display: none;
      }

      .remove-wrapper { 
   
        display: flex;
      }
    }

    .el-icon-circle-close{ 
   
      position: absolute;
      top: 0;
      right: 0;
      font-size: 20px;
      color: #F56C6C;
    }
  }

  .remove-wrapper { 
   
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    justify-content: center;
    align-items: center;
    background-color: rgba(0, 0, 0, 0.5);
  }

  .icon-success { 
   
    position: absolute;
    right: -15px;
    top: -6px;
    width: 40px;
    height: 24px;
    // line-height: 24px;
    text-align: center;
    background: #13ce66;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-box-shadow: 0 0 1pc 1px rgba(0, 0, 0, 0.2);
    box-shadow: 0 0 1pc 1px rgba(0, 0, 0, 0.2); .el-icon-check { 
   
      color: #ffffff;
      -webkit-transform: rotate(-45deg);
      transform: rotate(-45deg);
    }
  }
  .el-icon-delete { 
   
    font-size: 20px;
    color: #fff;
    cursor: pointer;
  }
}

这样使用的时候就可以直接引入组件使用了,绑定的值也是可以通过v-midel双向了
这就是最终的呈现效果啦!!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/190462.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Git2.21下载安装及使用教程

    Git2.21下载安装及使用教程Git2.21下载安装及使用教程Git下载安装教程下载Git下载地址:https://git-scm.com/downloads安装步骤1.选择组件,全部勾选,点击next2.选择git使用的默认编辑器3.选择git使用的默认编辑器UseGitfromGitBashonly(安全)只在GitBash中使用Git命令行工具Gitfromthecomm…

    2022年5月13日
    32
  • CSS伪类与伪元素「建议收藏」

    CSS伪类与伪元素「建议收藏」为什么要引入伪类与伪元素?css引入伪类和伪元素概念是为了格式化文档树以外的信息。也就是说,伪类和伪元素是用来修饰不在文档树中的部分,比如,一句话中的第一个字母,或是列表中的第一个元素,又或者是鼠标悬停在某个超链接上时要设置的样式。什么是伪类,伪元素?伪类:用于当已有元素处于的某个状态时,为其添加对应的样式,这个状态是根据用户行为而动态变化的。比如说,当用户悬停在指定的元素时,我们可以…

    2022年10月21日
    0
  • java查看环境变量的命令_java环境变量配置好了

    java查看环境变量的命令_java环境变量配置好了Linux是一个多用户的操作系统。每个用户登录系统后,都会有一个专用的运行环境。通常每个用户默认的环境都是相同的,这个默认环境实际上就是一组环境变量的定义。在Windows下,查看环境变量的命令是:set,这个命令会输出系统当前的环境变量。Linux下Linux查看环境变量准确的说是REDHAT下应该如何查看呢,命令是:export如果你想查看某一个名称的环境变量,命令是:echo$环境变量名,…

    2022年10月1日
    0
  • 一款用C++语言实现的3D游戏引擎(附源码),适用于想学3D游戏开发

    一款用C++语言实现的3D游戏引擎(附源码),适用于想学3D游戏开发C++技术牛人,编写实现的3D游戏演示Demo源代码。框架清晰,三维效果ok,适用于所有人学习3D游戏开发。【注】GetDeviceCaps(hDC,LOGPIXELSY)用于取得每英寸有多少像素MulDiv函数(被乘数,分子,分母)=nPointSize*GetDeviceCaps(hDC,LOGPIXELSY)/72,如果不支持硬件顶点处理,可以使用软件…

    2022年5月9日
    56
  • Matlab Error (Matrix dimensions must agree)

    Matlab Error (Matrix dimensions must agree)

    2022年1月15日
    150
  • String与StringBuffer的区别?

    String与StringBuffer的区别?String:1.String创建的对象是不可变的,一旦创建不可改变2.对象值可以改变其实是创建了一个新的对象,然后把新的值保存进去(如图1)3.String类被final修饰,不可以被继承4.String创建的对象的值存在于常量池,不用的时候不会被销毁5.String运行时间较长6.String适用于比较短而小的字符串图1StringBuffer:1.StringBuffer创建的对象是可变的2.它的改变不像String那样重新创建对象,而是通过构造方法(如图2)3.StringBu

    2022年9月21日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号