css3 flex layout justify-content:space-between the last line is aligned to the left

css3 flex layout justify-content:space-between the last line is aligned to the left

When using justify-content:space-between layout, using justify-self: start; for the last row of elements has no effect. I checked and found that CSS3 flexbox is not supported yet.

So how do you make the last line left-aligned?

Several existing solutions

  • Use tag elements to complete missing items
  • Using grid
  • Using Pseudo-Classes

In the case of pseudo-classes, if the last element is full, there will be a placeholder, the grid will have compatibility issues, and we don’t want to add new tags.

Left alignment for each row with a fixed number of columns

Since the number of columns is fixed, we can calculate margin-right value of the last element to ensure complete left alignment.

Assuming that each row has only three columns of elements, margin-right processing is required only when the last element is in the second column (i.e. li:last-child:nth-child(3n + 2) ), and the distance is the width of one element + the gap width.

Assuming the element width is $width , the distance required for the above situation is: (100% - 3 * $width) / 2 + $width => (100% - $width) / 2

.list1 li:last-child:nth-child(3n + 2) {
  margin-right: calc((100% - $width) / 2);
} 

Similarly, in the case of one row and four columns, we need to handle two cases: the last element is in the second column and the last element is in the third column.

.list2 li:last-child:nth-child(4n + 2) {
  margin-right: calc((100% - $width) / 3 * 2);
}
.list2 li:last-child:nth-child(4n + 3) {
  margin-right: calc((100% - $width) / 3 * 1);
} 

Click here to view the demo code

Left alignment for each row with an unfixed number of columns

I think the best solution is to use grid. There are a lot of them on the Internet, so I won’t discuss them here.

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

<<:  9 great JavaScript framework scripts for drawing charts on the web

>>:  3 ways to add links to HTML select tags

Recommend

Detailed explanation of JavaScript's Set data structure

Table of contents 1. What is Set 2. Set Construct...

Detailed explanation of CSS label mode display property

The code looks like this: <!DOCTYPE html> &...

JavaScript implementation of carousel example

This article shares the specific code for JavaScr...

Vue routing returns the operation method of restoring page status

Route parameters, route navigation guards: retain...

Modify the boot time of grub in ubuntu

The online search to modify the grub startup time...

Analysis of multi-threaded programming examples under Linux

1 Introduction Thread technology was proposed as ...

Detailed steps for installing nodejs environment and path configuration in Linux

There are two ways to install nodejs in linux. On...

A simple method to be compatible with IE6's min-width and min-height

If a website is widescreen, you drag the browser ...

How to install and use Ubuntu Docker

Table of contents 1. Automatic installation using...

UDP connection object principle analysis and usage examples

I wrote a simple UDP server and client example be...

How to use nginx to configure access to wgcloud

The nginx configuration is as follows: Such as ht...

Tutorial on building nextcloud personal network disk with Docker

Table of contents 1. Introduction 2. Deployment E...

jQuery realizes dynamic particle effect

This article shares the specific code of jQuery t...

Example code for circular hover effect using CSS Transitions

This article introduces Online preview and downlo...