在vue3 中,使用element-plus中的el-scrollbar,让内容元素自动滚动

文章介绍了如何在Vue3项目中使用Element-Plus的el-scrollbar实现元素内容滚动,当内容过大时自动滑动到底部后返回顶部,以及如何通过mouseenter和mouseleave事件控制滚动的暂停和恢复。
摘要由CSDN通过智能技术生成


在vue3 中,使用element-plus中的el-scrollbar,在el-scrollbar中如果元素过大出现滑动,就自动滑动,到底部时就返回顶部重新向下滑动,鼠标放入框内停止滑动

模板部分:

<template>
  <el-scrollbar ref="scrollArea" class="scroll-container" @mouseenter="stopScroll" @mouseleave="startScroll">
    <div class="scroll-content">
      <!-- 这里放入你想滚动的内容 -->
    </div>
  </el-scrollbar>
</template>

脚本部分:

import { ref, onMounted, onUnmounted } from 'vue';
import { ElScrollbar } from 'element-plus';

export default {
  components: {
    ElScrollbar
  },

  setup() {
    const scrollArea = ref(null);
    let timer = null;
    const SCROLL_SPEED = 1; // 每次滚动的像素数,可以根据需要调整

    const startScroll = () => {
      if (timer) {
        clearInterval(timer);
      }
      timer = setInterval(() => {
        // 获取滚动容器
        const container = scrollArea.value.$el.querySelector('.el-scrollbar__wrap');
        // 判断是否已滚动到底部
        if (container.scrollHeight - (container.scrollTop + container.clientHeight) <= 0) {
          // 滚动到顶部
          container.scrollTop = 0;
        } else {
          // 向下滚动
          container.scrollTop += SCROLL_SPEED;
        }
      }, 30); // 根据需要调整滚动间隔
    };

    const stopScroll = () => {
      if (timer) {
        clearInterval(timer);
      }
    };

    onMounted(() => {
      startScroll();
    });

    onUnmounted(() => {
      stopScroll();
    });

    return {
      scrollArea,
      startScroll,
      stopScroll
    };
  }
};

样式部分:

.scroll-container {
  width: 100%;
  height: 300px; /* 你可以根据需要调整高度 */
}

.scroll-content {
  /* 根据内容进行相应样式调整 */
}

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Vue3内置的v-model以及element-plus提供的el-form和el-form-item组件,设置相应的验证规则和提示信息即可。 示例代码如下: ```html <template> <el-form ref="form" :model="formData" :rules="formRules"> <el-form-item label="用户名" prop="username"> <el-input v-model="formData.username"></el-input> </el-form-item> <el-form-item label="密码" prop="password"> <el-input v-model="formData.password" type="password"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </template> <script> import { ref } from 'vue'; import { ElMessage } from 'element-plus'; export default { name: 'FormValidation', setup() { const formData = ref({ username: '', password: '', }); const formRules = ref({ username: [{ required: true, message: '请输入用户名', trigger: 'blur', }], password: [{ required: true, message: '请输入密码', trigger: 'blur', }], }); const submitForm = () => { // 提交表单操作 const form = ref('form'); form.value.validate((valid) => { if (valid) { // 验证通过执行提交操作 ElMessage.success('提交成功'); } else { ElMessage.warning('请填写完整信息'); return false; } }); }; return { formData, formRules, submitForm, }; }, }; </script> ``` 在这个示例,我们使用了ref来创建响应式对象formData和formRules,formData用于存放表单数据,formRules用于存放表单的验证规则。 el-form组件作为表单容器,通过ref="form"指定参考名称,然后通过:model绑定formData数据模型,用:rules绑定表单验证规则。 el-form-item组件作为表单元素的包裹容器,通过label属性指定标签文字,再使用prop属性命名表单元素的key,与表单验证规则对应。 验证规则定义可包括以下属性: - required:表示是否为必填字段 - message:表示验证不通过时的提示信息 - trigger:表示触发验证的事件,默认为blur 最后,在提交表单时,我们使用validate方法对表单进行验证,需要在回调函数判断验证结果并作出相应操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值