


How to use CSS Flex to achieve the same height border of left and right layout?
Tips for implementing the left and right columns contour borders under CSS Flex layout
When using CSS Flex layout, you often need to divide the page into two parts, and the lower part is then subdivided into two columns. If the heights of the left and right columns are not fixed, how can we ensure that the borders that divide them can automatically extend to the highest height? This article provides two solutions to solve this problem.
Scene: The page is divided into two parts, the upper and lower parts, and the lower part adopts a Flex layout. The height of the left and right columns is uncertain, so a border of equal height is needed between the two columns.
Solution 1: jQuery adjustment based on existing structure
If the HTML structure cannot be modified, this method can be used. First, set height: min-content;
for the right element (assuming it is .rht
) so that its height is adaptable to the content. Then, use jQuery to get the height of .rht
and apply it to the child elements of the left element (assuming it is .lft
):
let h = $(".rht").height() 'px'; $(".lft div").css({ height: h });
This method relies on JavaScript and needs to be executed after the page is loaded.
Solution 2: Adjust HTML structure and CSS style
This method is simpler and more efficient, without JavaScript. Contour borders can be implemented more elegantly by adjusting HTML structure and CSS styles.
Improved HTML structure:
<div class="wrapper"> <div class="top">Top content</div> <!-- Top area--> <div class="content"> <!-- Flex layout container--> <div class="lft"> <div>Content on the left</div> </div> <div class="rht"> <div>Content on the right</div> </div> </div> </div>
Corresponding CSS style:
* { padding: 0; border: 0; margin: 0; box-sizing: border-box; /* It is recommended to add to avoid borders affecting element size calculation*/ } .wrapper { height: 100vh; /* Occupies the entire viewport height*/ display: flex; flex-direction: column; /* Vertical layout*/ } .top { height: 100px; background: #e3e3e3; } .content { display: flex; flex: 1; /* occupy the remaining space*/ min-height: 0; /* Prevent minimum height from affecting the layout*/ } .lft { flex: 1; /* occupy the remaining space*/ } .rht { width: 600px; border-left: 1px solid red; min-height: 0; /* Prevent minimum height from affecting the layout*/ }
In this plan:
-
.wrapper
usesflex-direction: column;
to achieve vertical layout. -
.content
usesflex: 1;
to occupy the remaining space to ensure its height is adaptable. - Both
.lft
and.rht
usemin-height: 0;
to prevent the minimum height from limiting its height. - The split line is
border-left
directly on.rht
.
Solution 2 is implemented through pure CSS, which has better performance and is easier to maintain. It is recommended to give priority to the use of Plan 2.
The above is the detailed content of How to use CSS Flex to achieve the same height border of left and right layout?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

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

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The roles of HTML, CSS and JavaScript in web development are: 1. HTML defines the web page structure, 2. CSS controls the web page style, and 3. JavaScript adds dynamic behavior. Together, they build the framework, aesthetics and interactivity of modern websites.

When developing websites using CraftCMS, you often encounter resource file caching problems, especially when you frequently update CSS and JavaScript files, old versions of files may still be cached by the browser, causing users to not see the latest changes in time. This problem not only affects the user experience, but also increases the difficulty of development and debugging. Recently, I encountered similar troubles in my project, and after some exploration, I found the plugin wiejeben/craft-laravel-mix, which perfectly solved my caching problem.

VprocesserazrabotkiveB-enclosed, Мнепришлостольностьсясзадачейтерациигооглапидляпапакробоглесхетсigootrive. LEAVALLYSUMBALLANCEFRIABLANCEFAUMDOPTOMATIFICATION, ČtookazaLovnetakProsto, Kakaožidal.Posenesko

How does the Redis caching solution realize the requirements of product ranking list? During the development process, we often need to deal with the requirements of rankings, such as displaying a...

When developing a new content management system (CMS), I encountered a common but difficult problem: how to quickly build a fully functional CMS without adding too much complexity. There are many ready-made CMS solutions available on the market, but they are often too large and complex to configure and can be a burden for small projects. After some exploration, I discovered the lebenlabs/simplecms library, which provides a simple and efficient solution through Composer.

In the process of developing a website, improving page loading has always been one of my top priorities. Once, I tried using the Miniify library to compress and merge CSS and JavaScript files in order to improve the performance of the website. However, I encountered many problems and challenges during use, which eventually made me realize that Miniify may no longer be the best choice. Below I will share my experience and how to install and use Minify through Composer.

The top ten safe and reliable exchanges in the 2025 cryptocurrency circle include: 1. Binance, 2. OKX, 3. Gate.io (Sesame Open), 4. Coinbase, 5. Kraken, 6. Huobi Global, 7. Gemini, 8. Crypto.com, 9. Bitfinex, 10. KuCoin. These exchanges are rated as safe and reliable based on compliance, technical strength and user feedback.

Laravel 8 provides the following options for performance optimization: Cache configuration: Use Redis to cache drivers, cache facades, cache views, and page snippets. Database optimization: establish indexing, use query scope, and use Eloquent relationships. JavaScript and CSS optimization: Use version control, merge and shrink assets, use CDN. Code optimization: Use Composer installation package, use Laravel helper functions, and follow PSR standards. Monitoring and analysis: Use Laravel Scout, use Telescope, monitor application metrics.
