首页 > 其他分享 >使用Flex布局的几个小技巧

使用Flex布局的几个小技巧

时间:2024-12-12 21:32:06浏览次数:3  
标签:Flex direction 技巧 flex auto align 布局 test center

前情

Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性,任何一个容器都可以指定为 Flex 布局,如果说目前我开发中离不开的布局方式那就非Flex莫属了,而且小程序就是推荐使用Flex布局的,对 Grid布局的支持不太理想。

在一次次使用flex布局的时候遇到了一些小困扰,而解决这些小困扰的过程中发现了一些小技巧,特记录并分享出来。

技巧内容

技巧 1:flex-direction为column的子元素自适应内容宽

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <style>
	    .test {
			  width: 100%;
			  display: flex;
			  flex-direction: column;
			}
			.test-item {
			  height: 100px;
			  display: flex;
			  flex-direction: row;
			  justify-content: center;
			  align-items: center;
			  background-color: red;
			  color: white;
			}
			.test-item:nth-of-type(3){
			  align-self: flex-start;
			}
    </style>
  </head>
  <body>
      <div class="test">
        <div class="test-item">010101</div>
        <div class="test-item">020202</div>
        <div class="test-item">030303</div>
      </div>
  </body>
</html>

当设置为flex-direction: column后,项目元素align-self样式值默认为stretch,导致项目元素会充满整行,如果你想做到项目元素自适应内容宽你设置为align-self:baseline或者flex-start即可

上述示例可以实现如下图布局效果:

体验链接:CSS Playground

技巧 2:利用margin:auto实现一些特殊布局

对于如下需求你第一想到的flex布局方式是怎么实现:

按正常的实现思路是左边一个div包住左边内容,右边再一个div,再使用justify-content:between可以实现或者让左边的div为 flex:1,那有什么方式可以让结构打平一层,左边的包裹div免去了,那就是margin:auto,利用好margin:auto可以实现一些特殊布局,演示代码如下:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
	  <style>
	  .test,.test0,.test1 {
			  width: 100%;
			  display: flex;
			  flex-direction: row;
			  background-color: black;
			}
			.test-item,.test-item0,.test-item1 {
			  width: 100px;
			  height: 100px;
			  display: flex;
			  justify-content: center;
			  align-items: center;
			  color: white;
			  background-color: green;
			}
			.test-item:nth-last-of-type(1){
			  margin-left: auto;
			}
			.test-item0:nth-last-of-type(2){
			  margin-left: auto;
			}
			.test-item1:nth-of-type(2){
			  margin-left: auto;
			}
			.test-item1:nth-of-type(3){
			  margin-right: auto;
			}
	  </style>
  </head>
  <body>
    <div class="test">
      <div class="test-item">1</div>
      <div class="test-item">2</div>
      <div class="test-item">3</div>
      <div class="test-item">4</div>
    </div>
    <div class="test0">
      <div class="test-item0">1</div>
      <div class="test-item0">2</div>
      <div class="test-item0">3</div>
      <div class="test-item0">4</div>
    </div>
    <div class="test1">
      <div class="test-item1">1</div>
      <div class="test-item1">2</div>
      <div class="test-item1">3</div>
      <div class="test-item1">4</div>
    </div>
  </body>
</html>

上述示例可以实现如下图布局效果:

体验链接:CSS Playground

技巧 3:利用align-self实现交叉轴(Cross Axis)上单个元素位置控制

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <style>
	    .test {
			  display: flex;
			  flex-direction: column;
			  align-items: center;
			}
			.test-item {
			  width: 100px;
			  height: 100px;
			  display: flex;
			  flex-direction: row;
			  justify-content: center;
			  align-items: center;
			  color: white;
			  background-color: red;
			}
			.test-item:nth-of-type(1){
			  align-self: flex-start;
			}
			.test-item:nth-of-type(3){
			  align-self: flex-end;
			}
    </style>
  </head>
  <body>
    
    <div class="test">
      <div class="test-item">1</div>
      <div class="test-item">2</div>
      <div class="test-item">3</div>
    </div>

  </body>
</html>

通过align-items可以整体控制交项目元素在叉轴上的对齐方式,但如果想单个控制它的对齐方式,那就用好align-self吧,上述示例可以实现如下图布局效果:

体验链接:CSS Playground

技巧 4:使用gap设置容器内项目之间的间距

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
	  <style>
		  .wrap {
			  display: flex;
			  flex-direction: row;
			}
			.test {
			  width: 320px;
			  display: flex;
			  flex-direction: row;
			  align-items: center;
			  justify-content: space-between;
			  flex-wrap: wrap;
			  margin-right: 20px;
			}
			.test-item {
			  width: 100px;
			  height: 100px;
			  margin-bottom: 10px;
			  flex: none;
			  display: flex;
			  flex-direction: row;
			  justify-content: center;
			  align-items: center;
			  color: white;
			  background-color: red;
			}
			.test0 {
			  width: 320px;
			  display: flex;
			  flex-direction: row;
			  align-items: center;
			  flex-wrap: wrap;
			  margin-right: 20px;
			  gap: 10px 10px;
			}
			.test-item0 {
			  width: 100px;
			  height: 100px;
			  flex: none;
			  display: flex;
			  flex-direction: row;
			  justify-content: center;
			  align-items: center;
			  color: white;
			  background-color: red;
			}
	  </style>
  </head>
  <body>
    <div class="wrap">
      <div class="test">
        <div class="test-item">01</div>
        <div class="test-item">02</div>
        <div class="test-item">03</div>
        <div class="test-item">04</div>
        <div class="test-item">05</div>
        <div class="test-item">06</div>
        <div class="test-item">07</div>
        <div class="test-item">08</div>
      </div>

      <div class="test0">
        <div class="test-item0">11</div>
        <div class="test-item0">12</div>
        <div class="test-item0">13</div>
        <div class="test-item0">14</div>
        <div class="test-item0">15</div>
        <div class="test-item0">16</div>
        <div class="test-item0">17</div>
        <div class="test-item0">18</div>
      </div>
    </div>
  </body>
</html>

Flex布局如果不依赖gap想实现如下右图的布局是比较麻烦的,通过justify-content: space-between可以做到平分余下空间让元素间有间距,但是如果遇到未行元素不够的时候就会出现如下左图的问题,解决办法是手动生成一个空的元素让它补齐一行内容也是可以做到的;另一种实现方式是通过margin来实现元素间距,再通过:nth-child()方式来去除每行最边缘元素的margin。上述二种方式都相对比较麻烦,如果你使用gap就可以轻松实现右图效果

体验地址:CSS Playground

技巧 5:比较常用的几个缩写

flex: 1/flex: 0%; 等效于flex:1 1 0%; 子元素平分父元素空间,各子元素尺寸一样

flex: none; 等效于flex:0 0 auto; 元素保持自身原始大小不变

flex:auto; 等效于flex:1 1 auto; 元素尺寸可以弹性增大,也可以弹性变小,具有十足的弹性,项目会根据自身大小和剩余空间进行伸缩

注:flex:1和flex:auto区别:

  • flex-basis属性定义了项目在分配多余空间之前,占据的主轴空间(main size)
  • flex:1相当于flex: 1 1 0%,表示项目的基准大小为0%,不考虑项目本身的大小,只根据剩余空间进行伸缩
  • flex:auto相当于flex: 1 1 auto,表示项目的基准大小为auto,即项目本身的大小,同时也会根据剩余空间进行伸缩
  • 如果容器有足够的空间,flex:1和flex:auto都会平分剩余空间,但是flex:auto会保持项目本身的最小宽度,而flex:1不会
  • 如果容器没有足够的空间,flex:1会优先压缩内容,使得所有项目都能等分空间,而flex:auto会优先保持内容的完整性,挤压其他项目的空间

在线测试地址:JS Bin - Collaborative JavaScript Debugging

技巧 6:浏览器开发者工具辅助使用

对于新手刚刚学习使用flex布局,经常容易忘记一些属性,其实可以通过浏览器开发者工具辅助来学习flex布局,vs code也有对应的插件可以辅助

期望

上述只是个人在开发中发现的一些Flex布局小技巧,如果你有好的技巧欢迎也分享出来,共同学习进步。期待你的留言

标签:Flex,direction,技巧,flex,auto,align,布局,test,center
From: https://www.cnblogs.com/xwwin/p/18603495

相关文章

  • 鸿蒙UI布局-相对布局
    @Entry@ComponentstructIndex{@Statemessage:string='HelloWorld';build(){RelativeContainer(){Row().width(100).height(100).backgroundColor(Color.Black).alignRules({top:{anchor:'__container__',align......
  • 轻松上手:利用AI智能工具读懂电子配件产品说明书的技巧
    在购买和使用电子配件时,产品说明书是我们了解产品功能、操作方法以及注意事项的重要参考。然而,面对冗长、复杂的说明书,许多人往往感到无所适从。本文将介绍如何利用Helplook工具,轻松读懂电子配件的产品说明书,确保你能够正确、安全地使用电子配件。一、明确阅读目的与需求在......
  • 善用ChatGPT:用AI高效写出优质论文的5个技巧
    写在前面,除了ChatGPT,其他AI聊天机器人也能实现相同甚至更好的效果。比如Copilot、Perplexity、Gemini甚至kimi、豆包等都能联网,而且所有回答都会附上源链接,如果你不想用ChatGPT,这些也都是不错的替代选择。无论你选择哪个AI聊天机器人,以下技巧都能帮你充分利用AI助手的功能。......
  • 转载:【AI系统】布局转换原理与算法
    数据布局转换目前已经越来越多地用于编译器的前端优化,将内部数据布局转换为后端设备友好的形式。数据布局转换主要影响程序的空间局部性,所谓空间局部性指的是如果一个内存位置被引用了一次,那么程序很可能在不远的将来引用其附近的一个内存位置,它会影响到程序执行中的缓存及其他性......
  • 写一个三栏布局,中间固定,两边自适应(平均)
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><title>三栏布局</title><......
  • 写出不定宽度的子级div,在相对于固定宽度的父级元素水平居中的布局
    要实现不定宽子级div相对于固定宽度父级元素水平居中,可以使用几种方法:1.使用Flexbox:这是最现代化和推荐的方法,兼容性也很好。<divclass="parent"><divclass="child">不定宽度内容</div></div>.parent{width:500px;/*固定宽度*/display:flex;......
  • 使用div+css进行布局有什么好处?
    使用div+CSS进行布局在前端开发中有很多好处,总结如下:1.结构与样式分离:这是最重要的好处之一。HTML的div元素负责网页的结构和内容,而CSS负责网页的样式和外观。这种分离使得代码更清晰、易于维护和修改。例如,你可以轻松地改变整个网站的字体或颜色,而无需修改HTML结......
  • 响应式设计的有哪些技巧?有哪些好处?
    响应式设计的技巧有很多,可以大致分为以下几类:1.流式布局(FluidLayouts):使用相对单位:避免使用像素(px)等固定单位,尽量使用百分比(%)、em、rem、vw、vh等相对单位。这使得元素尺寸能够根据视口大小进行调整。弹性布局(Flexbox)和网格布局(Grid):Flexbox擅长于一维布......
  • 一些可能不太常见的C语言开发使用技巧
    1.复合字面量(CompoundLiterals)[C99]复合字面量是在C99中引入的,允许你在代码中直接定义结构体、数组或其他复杂数据类型的字面量。这种技巧可以简化代码,尤其是在需要临时生成复杂数据结构时。#include<stdio.h>structPoint{intx,y;};intmain(){//......
  • Layui open弹出输入法影响布局
    layui.openlayui.open里面有from表单。当点击input输入框弹出输入法,弹窗就会向下移动,导致弹窗下面的按钮溢出屏幕显示。//监听窗口大小变化事件$(window).on('resize',function(){varlayero=$('.layui-layer').eq(index);adjustLayerPosition(layero);});fu......