实现自定义指令 v-scrollBar,用于动态显示/隐藏滚动条,提升用户体验

javascript 复制代码
// src/directives/scrollbar.js
export default {
  mounted(el, binding) {
    // 初始化滚动条状态
    hideScrollbar(el);
    
    // 添加滚动事件监听
    let scrollTimer = null;
    
    const handleScroll = () => {
      // 显示滚动条
      showScrollbar(el);
      
      // 清除之前的定时器
      if (scrollTimer) {
        clearTimeout(scrollTimer);
      }
      
      // 设置新的定时器,在停止滚动后隐藏滚动条
      scrollTimer = setTimeout(() => {
        hideScrollbar(el);
      }, binding.value || 1000); // 默认1秒后隐藏,可通过指令参数自定义
    };
    
    // 保存定时器引用到元素上,便于销毁时清理
    el._scrollTimer = scrollTimer;
    el._scrollHandler = handleScroll;
    
    // 绑定滚动事件
    el.addEventListener('scroll', handleScroll);
  },
  
  unmounted(el) {
    // 清理事件监听和定时器
    if (el._scrollHandler) {
      el.removeEventListener('scroll', el._scrollHandler);
    }
    
    if (el._scrollTimer) {
      clearTimeout(el._scrollTimer);
    }
  }
};

// 显示滚动条的函数
function showScrollbar(el) {
  el.classList.add('show-scrollbar');
}

// 隐藏滚动条的函数
function hideScrollbar(el) {
  el.classList.remove('show-scrollbar');
}

使用

html 复制代码
<div class="record-wrap" v-scrollBar>
   <DynamicRecordSuvery :flag="flag" :messageId="messageId" :thoughtContents="thoughtContent" @getItem="getItem" />
</div>
css 复制代码
.record-wrap {
  flex-grow: 1;
  overflow-y: auto;
  margin-bottom: 10px;
  padding: 15px;
  /* 隐藏默认滚动条 */
  scrollbar-width: none; /* Firefox */
  &::-webkit-scrollbar {
    display: none; /* Chrome/Safari */
  }

  .record-box {
    width: 100%;
  }
}

/* 显示滚动条(指令添加.show-scrollbar时) */
.record-wrap.show-scrollbar {
   scrollbar-width: thin;
   &::-webkit-scrollbar {
       display: block;
       width: 8px;
   }
}
相关推荐
wuhen_n1 小时前
网络请求在Vite层的代理与Mock:告别跨域和后端依赖
前端·javascript·vue.js
小彭努力中1 小时前
193.Vue3 + OpenLayers 实战:圆孔相机模型推算卫星拍摄区域
vue.js·数码相机·vue·openlayers·geojson
用户69371750013846 小时前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
蓝帆傲亦6 小时前
Web 前端搜索文字高亮实现方法汇总
前端
用户69371750013846 小时前
Room 3.0:这次不是升级,是重来
android·前端·google
漫随流水8 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
踩着两条虫9 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
jzlhll12310 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
用头发抵命10 小时前
Vue 3 中优雅地集成 Video.js 播放器:从组件封装到功能定制
开发语言·javascript·ecmascript
蓝冰凌11 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js