码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【Vue-Element】Vue下配置好看的滚动条


    Vue下配置好看的滚动条

    • 1、原生代码优化
      • 1.1 滚动条组成
      • 1.2 简洁展示
      • 1.3 参考
    • 2、(vue组件-自定义滚动条)
    • 2.1 介绍
      • 2.1.1 安装
      • 2.1.2 属性 Attribute
      • 2.1.3 事件 Events
      • 2.1.4 方法 Methods
      • 2.2 使用
        • 2.2.1 引入组件
        • 2.2.2 Vue中使用
        • 2.2.3 给body设置自定义滚动条
    • 2.3 参考

    1、原生代码优化

    1.1 滚动条组成

    ::-webkit-scrollbar 滚动条整体部分
    ::-webkit-scrollbar-thumb 滚动条里面的小方块,能向上向下移动(或往左往右移动,取决于是垂直滚动条还是水平滚动条)
    ::-webkit-scrollbar-track 滚动条的轨道(里面装有Thumb)
    ::-webkit-scrollbar-button 滚动条的轨道的两端按钮,允许通过点击微调小方块的位置。
    ::-webkit-scrollbar-track-piece 内层轨道,滚动条中间部分(除去)
    ::-webkit-scrollbar-corner 边角,即两个滚动条的交汇处
    ::-webkit-resizer 两个滚动条的交汇处上用于通过拖动调整元素大小的小控件

    1.2 简洁展示

    说明:core_dialogue 为需要美化滚动条div盒子的类名,也可以按照需求更改为其他的名称。

    .core_dialogue {
      height: 100%;
      overflow: scroll;
    }
    .core_dialogue::-webkit-scrollbar-track-piece {
      background-color: #f8f8f800;
    }
    .core_dialogue::-webkit-scrollbar {
      width: 6px;
      transition: all 2s;
    }
    .core_dialogue::-webkit-scrollbar-thumb {
      background-color: #dddddd;
      border-radius: 100px;
    }
    .core_dialogue::-webkit-scrollbar-thumb:hover {
      background-color: #bbb;
    }
    .core_dialogue::-webkit-scrollbar-corner {
      background-color: rgba(255, 255, 255, 0);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    效果如下:

    【鼠标未选中】

    在这里插入图片描述

    【鼠标选中后】

    在这里插入图片描述

    1.3 参考

    1)CSS3自定义滚动条样式 -webkit-scrollbar
    2)CSS之设置滚动条样式
    3)美化element中的el-table滚动条
    4)gemini-scrollbar

    2、(vue组件-自定义滚动条)

    一般使用原生即可,组件有一些BUG,挺麻烦的,可以简单使用。
    介绍:vue-gemini-scrollbar
    官网:官网+Demo

    2.1 介绍

    2.1.1 安装

    npm install vue-gemini-scrollbar --save
    
    • 1

    2.1.2 属性 Attribute

    参数类型默认值说明
    autoCreateBooleantrue自动创建自定义滚动条
    autoshowBooleanfalsehover时才显示滚动条
    forceGeminiBooleanfalse原生滚动条可见的情况下,强制显示自定义滚动条(开发时会比较有用)
    minThumbSizeNumber20滚动条最小长度

    2.1.3 事件 Events

    事件名称回调参数说明
    readygeminiScrollbar实例GeminiScrollbar实例创建
    resize-滚动区域大小调整时触发

    2.1.4 方法 Methods

    方法名称说明
    create创建滚动区域
    update重新计算滚动区域大小(vue可以监听并触发组件updated的时候,都不需要你手动去调用它;但是像图片资源的load导致高度变化,你需要在合适的时候去手动调用;)
    destroy移除绑定事件及滚动条元素

    如何调用:
    监听ready事件,通过回调函数的参数geminiScrollbar实例来调用这些方法

    2.2 使用

    2.2.1 引入组件

    import Vue from 'vue'
    import GeminiScrollbar from 'vue-gemini-scrollbar'
    
    Vue.use(GeminiScrollbar)
    
    • 1
    • 2
    • 3
    • 4

    2.2.2 Vue中使用

    template:

    
        content...
    
    
    • 1
    • 2
    • 3
    • 4

    注意:只有内容溢出才会有滚动效果

    css:

    .my-scroll-bar{
        height:200px;
    }
    
    • 1
    • 2
    • 3

    添加自己的滚动条样式
    css:

    /* override gemini-scrollbar default styles */
    
    /* vertical scrollbar track */
    .gm-scrollbar.-vertical {
      background-color: #f0f0f0
    }
    
    /* horizontal scrollbar track */
    .gm-scrollbar.-horizontal {
      background-color: transparent;
    }
    
    /* scrollbar thumb */
    .gm-scrollbar .thumb {
      background-color: rebeccapurple;
    }
    .gm-scrollbar .thumb:hover {
      background-color: fuchsia;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    2.2.3 给body设置自定义滚动条

    因为vue组件的根元素不能为body,此时可以从Vue.$geminiScrollbar访问到GeminiScrollbar对象,然后你就可以自由使用它了(文档请参考:gemini-scrollbar)。

    css:

    html {
        height: 100%;
        /* or */
        height: 100vh;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    js:

    var scrollbar = new Vue.$geminiScrollbar({
        element: document.body
    }).create();
    
    • 1
    • 2
    • 3

    2.3 参考

    1)(vue组件-自定义滚动条)
    2)vue-gemini-scrollbar

  • 相关阅读:
    请收下这 10 个安全相关的开源项目
    Twitter正在测试年度订阅以进行推文和转推
    javascript函数式编程初探——什么是函数式编程?
    手动从0搭建ABP框架-ABP官方完整解决方案和手动搭建简化解决方案实践
    Java之Hashset(),LinkedHashset()
    物理服务器和云服务器的区别
    数据可视化-ECharts Html项目实战(1)
    .Net CLR GC动态获取函数头地址,C++的骚操作(慎入)
    【Linux_TODO】
    负载均衡算法实现
  • 原文地址:https://blog.csdn.net/feifeiyechuan/article/details/126156661
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号