CSS achieves the effect of hiding the scroll bar and scrolling the content (three ways)

CSS achieves the effect of hiding the scroll bar and scrolling the content (three ways)

We often encounter this situation in front-end development, where we need to support scrolling while hiding the scroll bar. The easiest way to think of it is to add an iscroll plug-in, but in fact, CSS can also achieve this function now. I have used it in many places. Let's take a look at these three methods.

Method 1: Calculate the scroll bar width and hide it

In the sidebar of this site, you can see that there is no scroll bar for the front-end daily report, but you can scroll the content by moving the mouse over it. What is this technology? In fact, I just hid the scroll bar by positioning it.

Demo

Here is a simplified version of the code.

<div class="outer-container">
    <div class="inner-container">
     ......
    </div>
</div>
.outer-container{
 width: 360px;
 height: 200px;
 position: relative;
 overflow: hidden;
}
.inner-container{
 position: absolute;
 left: 0;
 top: 0;
 right: -17px;
 bottom: 0;
 overflow-x:hidden;
 overflow-y: scroll;
}

This code cleverly moves the scroll bar 17 pixels to the right, which is exactly the width of the scroll bar. I got this value by manual debugging. No problem found in Chrome and IE.

Method 2: Use three containers to surround it, no need to calculate the width of the scroll bar

I first saw this code on a Microsoft blog. It is similar to my idea above, except that they added an extra box inside to confine the content inside the box. This way you can scroll without seeing the scroll bar.

The code is as follows:

<div class="outer-container">
     <div class="inner-container">
        <div class="content">
            ......
        </div>
     </div>
 </div>
//code from http://caibaojian.com/hide-scrollbar.html
.element, .outer-container {
  width: 200px;
  height: 200px;
}

.outer-container {
  border: 5px solid purple;
  position: relative;
  overflow: hidden;
}

.inner-container {
  position: absolute;
  left: 0;
  overflow-x:hidden;
  overflow-y: scroll;
}

.inner-container::-webkit-scrollbar {
  display: none;
}

Method 3: Hide the scroll bar with CSS

At the same time, the article also shares a method to hide the scroll bar through CSS, but this method is not compatible with IE and can only be used for mobile terminals.
That is the pseudo-object selector of the custom scroll bar::-webkit-scrollbar. For details, please see the previous article: CSS3 custom webkit scroll bar style

Chrome and Safari

.element::-webkit-scrollbar { width: 0 !important }
IE 10+

.element { -ms-overflow-style: none; }
Firefox

.element { overflow: -moz-scrollbars-none; }

Summarize

This concludes this article about how to use CSS to hide the scroll bar and scroll the content (three ways to achieve it). For more information about how to use CSS to hide the scroll bar and scroll the content, please search 123WORDPRESS.COM’s previous articles or continue browsing the related articles below. I hope you will support 123WORDPRESS.COM in the future!

<<:  Basic concepts and usage examples of HTML inline elements and block-level elements

>>:  Vue global filter concepts, precautions and basic usage methods

Recommend

How to convert JavaScript array into tree structure

1. Demand The backend provides such data for the ...

Tutorial on processing static resources in Tomcat

Preface All requests in Tomcat are handled by Ser...

Avoid abusing this to read data in data in Vue

Table of contents Preface 1. The process of using...

Implementation of nginx proxy port 80 to port 443

The nginx.conf configuration file is as follows u...

Detailed graphic tutorial on installing centos7 virtual machine in Virtualbox

1. Download centos7 Download address: https://mir...

Example of how to generate random numbers and concatenate strings in MySQL

This article uses an example to describe how MySQ...

How to disable ads in the terminal welcome message in Ubuntu Server

If you are using the latest Ubuntu Server version...

How to install nginx in centos7

Install the required environment 1. gcc installat...

How to split data in MySQL table and database

Table of contents 1. Vertical (longitudinal) slic...

SQL group by to remove duplicates and sort by other fields

need: Merge identical items of one field and sort...

10 Tips for Mobile App User Interface Design

Tip 1: Stay focused The best mobile apps focus on...

A simple example of creating a thin line table in html

Regarding how to create this thin-line table, a s...

Mysql implements three functions for field splicing

When exporting data to operations, it is inevitab...

Solution to the MySQL server has gone away error

MySQL server has gone away issue in PHP 1. Backgr...