浏览器滚动条样式终极方案

首先各个浏览器滚动条保持统一是不可能的,因为浏览器不支持大多数滚动条样式属性

从支持可调整的角度来看,我们一般选择

  • 保持chrome样式,其他浏览器样式使用默认效果
  • 保持chrome、火狐样式一致,其他浏览器样式使用默认效果

所以这里有二个方案自行选择

方案一

保持chrome样式,其他浏览器样式使用默认效果

(通常采用这个方案)
使用该方法就不要在非伪元素中使用 scrollbar-width:thin; 因为该属性会强行修改样式,导致自定义样式没有效果,虽然它在火狐浏览器中,让滚动条好看,苗条了些;

/*定义整个滚动条高宽及背景:高宽分别对应横竖滚动条的尺寸*/
&::-webkit-scrollbar {width:10px;background-color:#F5F5F5;
}
/*定义滚动条轨道:内阴影+圆角*/
&::-webkit-scrollbar-track {background-color:#F5F5F5;
}
/*定义滑块:内阴影+圆角*/
&::-webkit-scrollbar-thumb {border-radius:10px;background-color:#555;
}

当然可以自己写滚动条,不采用系统自带的,当然比较麻烦吧!!!
想搞一下的,可以参考 有道文档翻译 阅读界面中,滚动条效果

方案二

保持chrome、火狐样式一致,其他浏览器样式使用默认效果

这种方法可调整样式固定,没有圆角,美感一般

&::-webkit-scrollbar {width: 6px;background-color: #eee;
}&::-webkit-scrollbar-thumb {background-color: #c1c1c1;&:hover {background-color: #a8a8a8;}&:active {background-color: #787878;}
}& {scrollbar-width: thin;scrollbar-color: #c1c1c1 #eee;
}

Firefox

火狐64位目前只提供了部分自定义滚动条的属性:

scrollbar-width:该属性可取值:
scrollbar-width: auto; // 默认值
scrollbar-width: thin; // 比默认滚动条窄
scrollbar-width: none; // 不显示滚动条,但是仍可以滚动
scrollbar-color:其可填写的值有:
scrollbar-color: auto; // 默认值
scrollbar-color: dark; // 无效果
scrollbar-color: light; // 无效果
scrollbar-color: red green; // 第一个滚轮颜色,第二个滚动条背景色

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/804477.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++智能指针2——unique_ptr和weak_ptr

unique_ptr 一个unique_ptr“拥有”它所指向的对象。 与shared_ptr不同,某个时刻只能有一个unique_ptr指向一个给定对象。 当unique_ptr被销毁时,它所指向的对象也被销毁。 和shared_ptr 不同,没有类似make_shared的标准库函数返回一个un…

【双指针】两数之和|| 输入有序数组

两数之和|| 输入有序数组 给你一个下标从 1 开始的整数数组 numbers &#xff0c;该数组已按 非递减顺序排列 &#xff0c;请你从数组中找出满足相加之和等于目标数 target 的两个数。如果设这两个数分别是 numbers[index1] 和 numbers[index2] &#xff0c;则 1 < index1 …

在Linux系统上实现TCP(socket)通信

一.什么TCP TCP&#xff08;传输控制协议&#xff09;是一种面向连接的、可靠的、基于字节流的传输层通信协议。 二.TCP通信流程 三. TCP 服务器端 1 创建socket int sockfd socket(AF_INET, SOCK_STREAM, 0); //SOCK_STREAM tcp通信2 绑定(bind) struct sockaddr_in myad…

Ubuntu下无法获得锁 / 检测到系统程序错误 / E: Could not get lock /var/lib/apt/lists/lock

这里写自定义目录标题 Ubuntu下无法获得锁 错误 / E: Could not get lock /var/lib/apt/lists/lock Ubuntu下无法获得锁 错误 / E: Could not get lock /var/lib/apt/lists/lock 1、E: Could not get lock /var/lib/apt/lists/lock - open (11: Recource temporarily unavaila…

【双指针】删除有序数组中的重复项Ⅱ

给你一个有序数组 nums &#xff0c;请你 原地 删除重复出现的元素&#xff0c;使得出现次数超过两次的元素只出现两次 &#xff0c;返回删除后数组的新长度。 不要使用额外的数组空间&#xff0c;你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成 示例 1&…

C++实现幻方实验

我们这个实验目的是实现大于2的奇数的n阶幻方 根据上述的例子我们可以看到一些规律&#xff0c;显示1放在最上方中间的位置&#xff0c;然后向右上方延申&#xff0c;在达到n这个数字时&#xff0c;停止延申&#xff0c;然后在n的下方开始n1的新一轮延申。明白了原理之后就很容…

计算机专业,不擅长打代码,考研该怎么选择?

考研其实和你的代码能力关系不大 所以在选学校以前可以看看有哪些学校复试是要求上机撸代码的&#xff0c;可能会要求比较严 初试真的不用担心代码问题&#xff0c;我也是基本零编程能力就开始备考考研的... 本人双非科班出身备考408成功上岸&#xff0c;在这里也想给想考40…

css面试题--定位与浮动

1、为什么需要清除浮动&#xff1f; 在非IE浏览器下&#xff0c;容器不设高度且子元素浮动时&#xff0c;容器高度不能被内容撑开&#xff0c;内容会溢出到容器外面而影响布局。这种现象被称为浮动。 浮动的原理&#xff1a;浮动元素脱离文档流&#xff0c;不占用空间&#xff…

在 JavaScript或Typescript 中编写异步构造函数的正确方法

参考&#xff1a;The Proper Way to Write Async Constructors in JavaScript - DEV Community

使用 wangeditor 解析富文本并生成目录与代码块复制功能

在 Web 开发中&#xff0c;经常需要使用富文本编辑器来编辑和展示内容。wangeditor 是一个强大的富文本编辑器&#xff0c;提供了丰富的功能和灵活的配置&#xff0c;但是官方并没有提供目录导航和代码块的复制功能&#xff0c;所以我自己搞了一个 <template><div cla…

5个超好用的Python工具,赶紧码住!

Python开发软件可根据其用途不同分为两种&#xff0c;Python代码编辑器和Python集成开发工具&#xff0c;两者配合使用极大的提高Python开发人员的编程效率。掌握调试、语法高亮、Project管理、代码跳转、智能提示、自动完成、单元测试、版本控制等操作。 Python常用工具&…

小白新手学习 Python 使用哪个 Linux 系统更好?

对于小白新手学习Python&#xff0c;选择哪个Linux系统是一个很重要的问题&#xff0c;因为不同的Linux发行版&#xff08;distribution&#xff09;有着不同的特点、优势和适用场景。在选择时&#xff0c;需要考虑到易用性、学习曲线、社区支持等因素。 Ubuntu Ubuntu 是一个…

分布式系统中的唯一ID生成方法

通常在分布式系统中&#xff0c;有生成唯一ID的需求&#xff0c;唯一ID有多种实现方式。我们选择其中几种&#xff0c;简单阐述一下实现原理、适用场景、优缺点等信息。 目录 数据库多主复制UUID工单服务器雪花算法总结 数据库多主复制 数据库通常有自增属性&#xff0c;在单机…

CSS 实现无限波浪边框卡片

CSS 实现无限波浪边框卡片 效果展示 鼠标悬停效果&#xff0c;底部色块的边框是无限滚动的波浪 鼠标没有悬停效果 CSS 知识点 CSS 基础知识回顾使用 radial-gradient 实现波浪边框使用 anumate 属性实现波浪边框动画和控制动画运动 波浪实现原理 波浪边框的实现思路其…

dayjs 判断是否今天、本周内、本年内、本年外显示周几、月份等

效果: 判断是否今天需从 dayjs 中引入 isToday 插件&#xff1b; 判断是否两个日期之间需从 dayjs 中引入 isBetween 插件 import dayjs from dayjs import isToday from dayjs/plugin/isToday import isBetween from dayjs/plugin/isBetween// 注册插件 dayjs.extend(isBet…

浅谈对线程的理解

一、线程的概念 1、线程的概念 在Python中&#xff0c;想要实现多任务还可以使用多线程来完成。 2、为什么使用多线程&#xff1f; 进程是分配资源的最小单位 , 一旦创建一个进程就会分配一定的资源 , 就像跟两个人聊QQ就需要打开两个QQ软件一样是比较浪费资源的 . 线程是…

DP:子数组模型

一、最大子数组和 . - 力扣&#xff08;LeetCode&#xff09; 二、环形子数组的最大和 . - 力扣&#xff08;LeetCode&#xff09; class Solution { public:int maxSubarraySumCircular(vector<int>& nums) {//动态规划思想解决 //环形数组问题&#xff0c;尝试转…

01-Git 快速入门

https://learngitbranching.js.org/?localezh_CN在线练习git 1. Git 安装好Git以后, 先检查是否已经绑定了用户名和邮箱 git config --list再检查C:\Users\xxx.ssh 下是否存在 id_rsa.pub , 存在的话复制其内容到 GitHub 的 SSH KEY 中 没有这一步, PUSH操作的时候会报错:…

土壤墒情监测系统:洞察土壤水分奥秘

TH-TS400土壤墒情监测系统&#xff0c;作为现代农业科技的重要组成部分&#xff0c;已经成为农业生产过程中不可或缺的一环。该系统通过先进的传感器技术和数据处理能力&#xff0c;能够实时监测土壤的水分状况&#xff0c;为农业生产提供精准、可靠的数据支持。本文将从系统构…

存储设备与网络监控运维实践

随着企业数据量的不断增长和网络架构的日益复杂&#xff0c;存储设备和网络设施的稳定运行变得至关重要。为了确保这些关键组件的性能和可用性&#xff0c;实施全面的监控策略是运维团队的首要任务。本文旨在为运维团队提供存储设备监控、网络流量分析以及网络配置管理方面的参…