css 隐藏滚动条-窗口中文本,图片移动PC端

使用 CSS 隐藏滚动条,如果直接使用 overflow: hidden 会导致内容不能滚动,要想使用 css 隐藏滚动条,但不影响内容滚动,这里有两种方法:

  • 使用 padding 把滚动条移出浏览器视口。
  • 使用 ::webkit-scrollbar 伪元素选择器。

下面分别来看一下这两种方法。

隐藏滚动条

要仅隐藏垂直滚动条,或仅隐藏水平滚动条,请使用 overflow-yoverflow-x:

实例

xml 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>在网页上隐藏滚动条</title>
<style>
    body {  
  overflow-y: hidden; /* 隐藏垂直滚动条 */  
  overflow-x: hidden; /* 隐藏水平滚动条 */  
}
</style>
</head>
<body>
    <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam eu sem tempor, varius quam at, luctus dui. Mauris magna metus.</p>
</body>
</html> 

或者,您可以通过将 overflow-x 属性设置为 hidden 来隐藏水平滚动条,通过将 overflow-y 属性设置为 hidden 来隐藏垂直滚动条。

隐藏滚动条但保留功能

使用 padding

使用 css padding 来隐藏滚动条的原理是,把右侧 padding 间距设置为和操作系统滚动条宽度一样的数值,把滚动条挤出浏览器外,这样滚动条就不会出现在浏览器右侧了,并且也不会影响内容滚动。

  • 我们先把 body 的滚动条隐藏,这样就不会有横向的滚动条了。
  • 然后把 main 元素的 overflow-y 设置为 scroll,让它可以垂直滚动。
  • 再把 main 元素的右侧间距 padding-right 设置为滚动条的宽度,这个根据操作系统会有不同。
css 复制代码
body {
  overflow: hidden;
}

conten {
  width: 100vw;
  height: 100vh;
  /* overflow-y 设置为 scroll,让它可以垂直滚动 */  
  overflow-y: scroll;
  /*把 main 元素的右侧间距 padding-right 设置为滚动条的宽度 */
  padding-right: 7px;
}

使用 ::webkit-scrollbar

第 2 种方式是使用 ::webkit-scrollbar 伪元素选择器,不过这个选择器只在 webkit 核心的浏览器中有效,例如 Chrome、新 Edge、Safari 等。::web-kit-scrollbar 可以直接选择滚动条元素,把它的 display 属性设置为 none 就可以隐藏滚动条了:

要隐藏滚动条,但仍能保持滚动,可以使用以下代码:

实例

css 复制代码
/* 隐藏 Chrome、Safari 和 Opera 的滚动条 */  
.example::-webkit-scrollbar {  
  display: none;  
}  
  
/* 隐藏 IE、Edge 和 Firefox 的滚动条 */  
.example {  
  -ms-overflow-style: none;  /* IE and Edge */  
  scrollbar-width: none;  /* Firefox */  
}

预览:

可以看到这两种效果。

相关推荐
汪子熙11 分钟前
Angular 服务器端应用 ng-state tag 的作用介绍
前端·javascript·angular.js
杨荧12 分钟前
【JAVA开源】基于Vue和SpringBoot的旅游管理系统
java·vue.js·spring boot·spring cloud·开源·旅游
Envyᥫᩣ19 分钟前
《ASP.NET Web Forms 实现视频点赞功能的完整示例》
前端·asp.net·音视频·视频点赞
Мартин.4 小时前
[Meachines] [Easy] Sea WonderCMS-XSS-RCE+System Monitor 命令注入
前端·xss
一 乐5 小时前
学籍管理平台|在线学籍管理平台系统|基于Springboot+VUE的在线学籍管理平台系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习
昨天;明天。今天。6 小时前
案例-表白墙简单实现
前端·javascript·css
数云界6 小时前
如何在 DAX 中计算多个周期的移动平均线
java·服务器·前端
风清扬_jd6 小时前
Chromium 如何定义一个chrome.settingsPrivate接口给前端调用c++
前端·c++·chrome
安冬的码畜日常6 小时前
【玩转 JS 函数式编程_006】2.2 小试牛刀:用函数式编程(FP)实现事件只触发一次
开发语言·前端·javascript·函数式编程·tdd·fp·jasmine
ChinaDragonDreamer6 小时前
Vite:为什么选 Vite
前端