vue监听滚动事件切换列表和监听onresize事件

2020-02-11  本文已影响0人  北风吹_yfy

vue监听鼠标滚动事件

<script>
    export default {
        name: "home",
        data(){
            return{
                scrollIndex: 0, // 滚动的当前下标
                currentAsideIndex: 0, // 当前侧边栏下标
            }
        },
        mounted () {
             //监听鼠标滚动事件,兼容chrome 、ie 和 firefox
            window.addEventListener('mousewheel',     this.debounce(this.handleScroll,300), true)||window.addEventListener("DOMMouseScroll",this.debounce(this.handleScroll,300),false)
        },
    },
        methods:{
            // 侧边栏切换
            setActiveItem (index) {
                  // 此处是引用elementUI的走马灯组件实现列表切换
                  this.$refs.carousel.setActiveItem(index)
                  this.currentAsideIndex = index
                  this.scrollIndex = index
        },
            //函数防抖
            debounce(func, wait) {
                let timeout;
                return function () {
                    let context = this;
                    let args = arguments;
                    if (timeout) clearTimeout(timeout);
                    timeout = setTimeout(() => {
                        func.apply(context, args)
                    }, wait);
                }
            },
            //判断滚动方向
           handleScroll (e) {
                let direction = e.deltaY > 0 ? 'down' : 'up'
                if (this.scrollIndex === 0) {
                      direction === 'down' ? this.scrollIndex++ : this.scrollIndex = 0
                } else if (this.scrollIndex === this.navList.length - 1) {
                      direction === 'down' ? this.scrollIndex = (this.navList.length - 1) :   this.scrollIndex--
               } else {
                    direction === 'down' ? this.scrollIndex++ : this.scrollIndex--
              }
              this.setActiveItem(this.scrollIndex)
           }                    
        }
</script>

vue监听onresize事件

<div class="box" :style="{height:screenHeight}"></div>

data () {
    return {
      screenHeight: '', // 页面内部的动态高度
    }
},
mounted(){
    // 监听浏览器窗口缩放事件
    this.screenHeight = (document.body.clientHeight - 100) + 'px'
    window.onresize = () => {
      return (() => {
        this.screenHeight = (document.body.clientHeight - 100) + 'px'
      })()
    }
}
上一篇 下一篇

猜你喜欢

热点阅读