zoukankan      html  css  js  c++  java
  • Vue 侧边滑出层

    <template>
      <div>
        <transition name="el-fade-in">
          <div class="proper__model" v-if="show" @click="hideProper"></div>
        </transition>
        <transition @before-enter="beforeEnter" @enter="enter" @leave="leave">
          <div :class="['proper__content',`proper__${placement}`]" :style="getClient()" v-if="show">
            <slot></slot>
          </div>
        </transition>
      </div>
    </template>
    
    <script>
    /**
     * 边界滑出层
     * @desc 在页面中弹出一个遮罩层,与一快内容区域
     * @param 见props
     * @example <slide-model v-model="showProper" placement="right" client="300">这里是content</slide-model>
     */
    export default {
      name: 'search-model',
      data () {
        return {
          show: this.value
        }
      },
      watch: {
        value: function (val) {
          this.show = val
        }
      },
      props: {
        value: {
          // 是否显示
          type: Boolean,
          default: false
        },
        placement: {
          type: String, // content出现位置
          default: 'right' // {left,top,bottom,right}
        },
        client: {
          // 内容区域的高度或者宽度,左边或者右边表示宽度,上边或者下边表示高度
          type: [String, Number],
          default: 300
        }
      },
      methods: {
        /**
         * 获取定位确定固定高或宽样式
         * @return {Object} style 内容区域高或宽样式
         */
        getClient () {
          let style = {}
          if (this.placement === 'top' || this.placement === 'bottom') {
            style = {
              height: this.client + 'px'
            }
          } else {
            style = {
               this.client + 'px'
            }
          }
          return style
        },
        /**
         * 隐藏弹窗
         */
        hideProper () {
          this.show = false
          this.$emit('input', this.show)
        },
        beforeEnter (el) {
          switch (this.placement) {
            case 'left':
              el.style.transform = `translateX(-${this.client}px)`
              break
            case 'right':
              el.style.transform = `translateX(${this.client}px)`
              break
            case 'top':
              el.style.transform = `translateY(-${this.client}px)`
              break
            case 'bottom':
              el.style.transform = `translateY(${this.client}px)`
              break
          }
          el.style.opacity = 0
        },
        enter (el, done) {
          done()
          el.style.transition = 'all .3s ease'
          el.style.transform = 'translateX(0px) translateY(0px)'
          el.style.opacity = 1
        },
        leave (el, done) {
          el.style.transition = 'all .2s ease'
          switch (this.placement) {
            case 'left':
              el.style.transform = `translateX(-${this.client}px)`
              break
            case 'right':
              el.style.transform = `translateX(${this.client}px)`
              break
            case 'top':
              el.style.transform = `translateY(-${this.client}px)`
              break
            case 'bottom':
              el.style.transform = `translateY(${this.client}px)`
              break
          }
          el.style.opacity = 0
          setTimeout(_ => {
            done()
          }, 1500)
        }
      }
    }
    </script>
    
    <style scoped lang="less">
    .proper__model {
      position: fixed;
      height: 100%;
      width: 100%;
      top: 0;
      left: 0;
      z-index: 1999;
      background-color: rgba(0, 0, 0, 0.3);
    }
    .proper__content {
      position: fixed;
      overflow: hidden;
      z-index: 2000;
      padding: 10px;
      box-shadow: 0 0 3px #fff;
      background-color: #fff;
    }
    .proper__left {
      bottom: 0;
      left: 0;
      height: 100%;
      padding-top: 20px;
    }
    .proper__right {
      bottom: 0;
      right: 0;
      height: 100%;
      padding-top: 20px;
    }
    .proper__top {
      top: 0;
      left: 0;
      width: 100%;
      padding-top: 20px;
    }
    .proper__bottom {
      bottom: 0;
      left: 0;
      width: 100%;
      padding-top: 20px;
    }
    </style>
  • 相关阅读:
    BZOJ1819 [JSOI]Word Query电子字典 Trie
    洛谷2973 [USACO10HOL]赶小猪Driving Out the Piggi… 概率 高斯消元
    BZOJ2669 [cqoi2012]局部极小值 状压DP 容斥原理
    BZOJ5047 空间传送装置 2017年9月月赛 最短路 SPFA
    BZOJ5045 打砖块 2017年9月月赛 其他
    BZOJ1858 [Scoi2010]序列操作 线段树
    BZOJ1826 [JSOI2010]缓存交换 堆 贪心
    BZOJ1898 [Zjoi2005]Swamp 沼泽鳄鱼 矩阵
    BZOJ1878 [SDOI2009]HH的项链 树状数组 或 莫队
    BZOJ1875 [SDOI2009]HH去散步 矩阵
  • 原文地址:https://www.cnblogs.com/jervy/p/13958977.html
Copyright © 2011-2022 走看看