Home Web Front-end CSS Tutorial CSS method to solve the gap caused by display:inline-block; layout

CSS method to solve the gap caused by display:inline-block; layout

May 21, 2017 am 10:38 AM
Block inline gap

This article mainly introduces the CSS method to solve the gap (gap) caused by display:inline-block;. It has certain reference value. If you need it, you can learn about it.

Today I used display:inline-block; when making H5 horizontal sliding cards, but found that there were gaps between elements on the same horizontal line. This is obviously not the effect I want, so I changed to left floating, which solved the gap problem, but the width of the parent element needs to be set to achieve horizontal left and right scrolling, which increases the amount of code, because the number of cards is not fixed, and its parent element needs to be set in real time. The width requires the use of js, so the amount of code increases, which is not the best choice. It seems that the best solution is to use display:inline-block;, so the gap problem arises. The code is as follows:


<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
<title>document</title>
<style>
*{margin:0;padding:0;}
.box{overflow-x:auto;background:#fff;white-space:nowrap;}
.box span{display:inline-block;width:100px;height:30px;line-height:30px;text-align:center;background:#f00;color:#fff;}
</style>
</head>
<body>
<p class="box">
    <span>111</span>
    <span>111</span>
    <span>111</span>
    <span>111</span>
</p>
</body>
</html>
Copy after login

The effect is as follows:

This gap obviously exists, and it is said that this performance is in compliance with the specification The expected performance is caused by whitespace characters caused by line breaks. But this effect is obviously not what we want. The gap we want is the margin we set according to our actual needs. So how to eliminate this gap? There are three methods:

Method one: No line breaks between elements, the code is as follows:


<p class="box">  <span>111</span><span>111</span><span>111</span><span>111</span>
</p>
Copy after login

The effect As follows:

Method 2: Set font-size:0 for its parent element; set the actual required size for itself Font size. The bad thing is that some browsers, like Chrome and Opera, have minimum font settings, but it seems that Chrome no longer has this setting. The code is as follows:

css:


.box{overflow-x:auto;background:#fff;white-space:nowrap;font-size:0;}
.box span{display:inline-block;width:100px;height:30px;line-height:30px;text-align:center;background:#f00;color:#fff;font-size:14px;}
Copy after login

html:


<p class="box">
    <span>111</span>
    <span>111</span>
    <span>111</span>
    <span>111</span>
</p>
Copy after login

The effect is as follows:

##Method three: For the negative margin method, it should be noted that this gap is related to the font size, so the gap is not a certain value.

Of the above three methods, the first two are better solutions, and the third method is not recommended. There are other solutions online, but I think the first two are better.

PS:

Combined with the comments and suggestions of the majority of front-end experts, you can also set display:flex to its parent element to eliminate gaps, and the amount of code is less, but it is used at my level The effect of sliding cards causes all elements to be in the visible window, and horizontal left and right sliding cannot be achieved.

The above is the detailed content of CSS method to solve the gap caused by display:inline-block; layout. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1662
14
PHP Tutorial
1262
29
C# Tutorial
1234
24
Google Fonts   Variable Fonts Google Fonts Variable Fonts Apr 09, 2025 am 10:42 AM

I see Google Fonts rolled out a new design (Tweet). Compared to the last big redesign, this feels much more iterative. I can barely tell the difference

How to Create an Animated Countdown Timer With HTML, CSS and JavaScript How to Create an Animated Countdown Timer With HTML, CSS and JavaScript Apr 11, 2025 am 11:29 AM

Have you ever needed a countdown timer on a project? For something like that, it might be natural to reach for a plugin, but it’s actually a lot more

HTML Data Attributes Guide HTML Data Attributes Guide Apr 11, 2025 am 11:50 AM

Everything you ever wanted to know about data attributes in HTML, CSS, and JavaScript.

A Proof of Concept for Making Sass Faster A Proof of Concept for Making Sass Faster Apr 16, 2025 am 10:38 AM

At the start of a new project, Sass compilation happens in the blink of an eye. This feels great, especially when it’s paired with Browsersync, which reloads

How We Created a Static Site That Generates Tartan Patterns in SVG How We Created a Static Site That Generates Tartan Patterns in SVG Apr 09, 2025 am 11:29 AM

Tartan is a patterned cloth that’s typically associated with Scotland, particularly their fashionable kilts. On tartanify.com, we gathered over 5,000 tartan

How to Build Vue Components in a WordPress Theme How to Build Vue Components in a WordPress Theme Apr 11, 2025 am 11:03 AM

The inline-template directive allows us to build rich Vue components as a progressive enhancement over existing WordPress markup.

PHP is A-OK for Templating PHP is A-OK for Templating Apr 11, 2025 am 11:04 AM

PHP templating often gets a bad rap for facilitating subpar code — but that doesn&#039;t have to be the case. Let’s look at how PHP projects can enforce a basic

Programming Sass to Create Accessible Color Combinations Programming Sass to Create Accessible Color Combinations Apr 09, 2025 am 11:30 AM

We are always looking to make the web more accessible. Color contrast is just math, so Sass can help cover edge cases that designers might have missed.

See all articles