溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

vue如何封裝圖片滑塊驗(yàn)證組件

發(fā)布時(shí)間:2022-03-31 14:42:53 來源:億速云 閱讀:331 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要為大家展示了“vue如何封裝圖片滑塊驗(yàn)證組件”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“vue如何封裝圖片滑塊驗(yàn)證組件”這篇文章吧。

具體內(nèi)容如下

滑塊驗(yàn)證組件整體不難,主要在于設(shè)置圖片的樣式問題,想要讓背景圖充滿div,就需要滑塊圖片也跟隨等比放大,效果與代碼如下:

vue如何封裝圖片滑塊驗(yàn)證組件

HTML:

<template>
  <section class="slider-section">
    <div class="img-box">
      <img :src="'data:image/png;base64,' + sliderData.bigImg" class="bg-img" ref="bgImg" />
      <img :src="'data:image/png;base64,' + sliderData.smallImg" class="slider-img" ref="sliderImg" />
    </div>
    <div class="slider-box">
      <span class="slider-text">向右滑動滑塊填充拼圖</span>
      <div class="slider-icon" @mousedown="rangeMove">></div>
    </div>
  </section>
</template>

JS:

<script>
export default {
  props: ['sliderData'], // 父組件傳入的滑塊數(shù)據(jù)對象
  watch: {
    sliderData: { // 監(jiān)聽滑塊數(shù)據(jù)變化,重置滑塊位置
      handler (newVal, oldVal) {
        if (newVal) {
          this.init()
        }
      },
      deep: true
    }
  },
  data () {
    return {
      disX: 0 // 滑塊距離背景圖左側(cè)的位置
    }
  },
  mounted () {
    this.init()
  },
  methods: {
    // 初始化滑塊的位置
    init () {
      this.disX = 0 // 初始化滑塊位置
      let bigImg = new Image() // 創(chuàng)建背景圖片
      bigImg.src = "data:image/png;base64," + this.sliderData.bigImg
      bigImg.onload = () => {
        let originWidth = bigImg.width  // 獲取原始背景圖片的寬度
        let widthRate = this.$refs.bgImg.width / originWidth // 背景圖片渲染后的實(shí)際寬度/原始圖片寬度
        let smallImg = new Image() // 創(chuàng)建滑塊圖片
        smallImg.src = "data:image/png;base64," + this.sliderData.smallImg
        this.$refs.sliderImg.src = 'data:image/png;base64,' + this.sliderData.smallImg // 設(shè)置滑塊圖片地址
        this.$refs.sliderImg.style.width = smallImg.width * widthRate + 'px'  // 設(shè)置滑塊圖片寬度
        this.$refs.sliderImg.style.top = this.sliderData.smallY * this.$refs.bgImg.height + 'px'  // 設(shè)置滑塊距離背景圖頂部的距離
        this.$refs.sliderImg.style.left = 0  // 設(shè)置滑塊距離背景圖左側(cè)的距離
      }
    },
    // 移動事件觸發(fā)
    rangeMove (e) {
      let ele = e.target
      let startX = e.clientX
      let eleWidth = ele.offsetWidth
      let parentWidth = ele.parentElement.offsetWidth
      let MaxX = parentWidth - eleWidth
      document.onmousemove = (e) => {
        let endX = e.clientX
        this.disX = endX - startX
        this.$refs.sliderImg.style.left = this.disX + 'px'
        if (this.disX <= 0) {
          this.disX = 0
          this.$refs.sliderImg.style.left = 0
        }
        if (this.disX >= MaxX - eleWidth) {//減去滑塊的寬度,體驗(yàn)效果更好
          this.disX = MaxX
          this.$refs.sliderImg.style.left = (parentWidth - this.$refs.sliderImg.width) + 'px'
        }
        ele.style.transition = '.1s all'
        ele.style.transform = 'translateX(' + this.disX + 'px)'
        e.preventDefault()
      }
      document.onmouseup = () => {
        this.$emit('submitPic', this.disX / parentWidth) // 停止滑動事件冒泡給父級
        setTimeout(() => {
          ele.style.transition = '.5s all'; // 初始化滑塊位置
          ele.style.transform = 'translateX(0)';
        }, 200)
        document.onmousemove = null
        document.onmouseup = null
      }
    }
  }
}
</script>

CSS:

<style scoped lang="less">
.slider-section {
  margin: 20px 0;
  .img-box {
    position: relative;
    .bg-img {
      width: 100%;
    }
    .slider-img {
      position: absolute;
      left: 0;
      top: 0;
    }
  }
 
  .slider-box {
    margin-top: 20px;
    background: #f7f9fa;
    color: #666;
    border: 1px solid #e4e7eb;
    position: relative;
    height: 30px;
    width: 100%;
    &:hover {
      box-shadow: 0 0 3px #ccc;
    }
    .slider-text {
      font-size: 14px;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
    }
    .slider-icon {
      width: 30px;
      height: 30px;
      background: #c8923a;
      text-align: center;
      font-size: 20px;
      color: #fff;
      box-shadow: 0 0 6px #ccc;
    }
  }
}
</style>

注:使用的是mousedown、onmousemove 、onmouseup 事件,僅支持PC端,如果要在移動端使用,需要把這些事件改成touch等;

以上是“vue如何封裝圖片滑塊驗(yàn)證組件”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

vue
AI