LayUI中的布局

article/2025/9/19 4:58:05

前言

最近在准备找工作的事项,但是作为一个后台也是需要了解一些前端框架的。就目前的来说有大火的VUE,但是VUE还是存在一定的学习成本,所以决定先从对后台友好的LayUI开始入手先做一些小项目练练手,后面会考虑使用VUE+ElementUI做一个大型一点的SAAS系统。查阅资料后得到如下文章,作为学习记录使用。

页面布局

容器布局

layui的页面布局可以使用布局容器进行布局。布局容器分为固定宽度和完整宽度。大部分时候我们使用的是固定宽度。

  • 固定宽度
    样式:layui-container
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>布局</title><!-- 引入LayUId的核心CSS--><link rel="stylesheet" type="text/css" href="layui/css/layui.css">
</head>
<body><!--布局容器1,固定宽度,两侧有留白效果2,完整宽度,占据屏幕的100%--><div class="layui-container" style="background-color: cyan;height: 300px">固定宽度</div></body>
</html>

在这里插入图片描述

  • 完整宽度
    样式:layui-fluid
<div class="layui-fluid" style="background-color: cyan;height: 300px">固定宽度
</div>

在这里插入图片描述

栅格布局

为了丰富网页布局,简化 HTML/CSS 代码的耦合,并提升多终端的适配能力,layui 在 2.0 的版本中引进了自己的一套具备响应式能力的栅格系统。我们将容器进行了 12 等分,预设了 4*12 种 CSS 排列类,它们在移动设备、平板、桌面中/大尺寸四种不同的屏幕下发挥着各自的作用。

栅格布局规则:
  • 采用 layui-row 来定义行,如:
<div class="layui-row"></div>
  • 采用类似 layui-col-md* 这样的预设类来定义一组列(column),且放在行(row)内
    其中:
    变量md 代表的是不同屏幕下的标记(可选值见下文)
    变量* 代表的是该列所占用的12等分数(如6/12),可选值为 1 - 12
    如果多个列的“等分数值”总和等于12,则刚好满行排列。如果大于12,多余的列将自动另起一行
  • 列可以同时出现最多四种不同的组合
    分别是:xs(超小屏幕,如手机)、sm(小屏幕,如平板)、md(桌面中等屏幕)、lg(桌面大型屏幕),以呈现更加动态灵活的布局
  • 可对列追加类似 layui-col-space5、 layui-col-md-offset3 这样的预设类来定义列的间距和偏移
  • 最后,在列(column)元素中放入你自己的任意元素填充内容,完成布局!
    如下代码所示:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>栅格系统</title><!-- 引入LayUId的核心CSS--><link rel="stylesheet" type="text/css" href="layui/css/layui.css">
</head>
<body><div class="layui-container"><!--定义行--><div class="layui-row"><!--定义列--><div class="layui-col-md5" style="background-color:darkviolet;height: 50px">内容的5/12</div><div class="layui-col-md7" style="background-color:deepskyblue;height: 50px">内容的7/12</div></div><!--定义行--><div class="layui-row"><!--定义列--><div class="layui-col-md4" style="background-color:mediumspringgreen;height: 50px">内容的4/12</div><div class="layui-col-md4" style="background-color:honeydew;height: 50px">内容的4/12</div></div></div>
</body>
</html>

在这里插入图片描述

栅格系统的自适用

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>栅格系统</title><!-- 引入LayUId的核心CSS--><link rel="stylesheet" type="text/css" href="layui/css/layui.css">
</head>
<body><div class="layui-container"><!--定义行--><div class="layui-row"><!--定义列--><div class="layui-col-md5" style="background-color:darkviolet;height: 50px">内容的5/12</div><div class="layui-col-md7" style="background-color:deepskyblue;height: 50px">内容的7/12</div></div><!--定义行--><div class="layui-row"><!--定义列--><div class="layui-col-md4" style="background-color:mediumspringgreen;height: 50px">内容的4/12</div><div class="layui-col-md4" style="background-color:honeydew;height: 50px">内容的4/12</div><div class="layui-col-md6" style="background-color:orangered;height: 50px">内容的6/12</div></div><hr><h3>平板和桌面端的不同表现</h3><div class="layui-row" ><div class="layui-col-sm6 layui-col-md4" style="background-color:dodgerblue;height: 50px">平板6/12,桌面端4/12</div></div><div class="layui-row" ><div class="layui-col-sm12 layui-col-md8" style="background-color:orchid;height: 50px">平板12/12,桌面端8/12</div></div></div>
</body>
</html>

桌面端效果
在这里插入图片描述
模拟平板/手机端效果
在这里插入图片描述

响应式规则

栅格的响应式能力,得益于CSS3媒体查询(Media Queries)的强力支持,从而针对四类不同尺寸的屏幕,进行相应的适配处理
在这里插入图片描述

响应式的公共类

在这里插入图片描述

列间距

通过“列间距”的预设类,来设定列之间的间距。且一行中最左的列不会出现左边距,最右的列不会出现右边距。列间距在保证排版美观的同时,还可以进一步保证分列的宽度精细程度。我们结合网页常用的边距,预设了 12 种不同尺寸的边距,分别是:

  • layui-col-space1
  • layui-col-space2
  • layui-col-space4
  • layui-col-space5
  • layui-col-space6
  • layui-col-space8
  • layui-col-space10
  • layui-col-space12
  • layui-col-space14
  • layui-col-space15
  • layui-col-space16
  • layui-col-space18
  • layui-col-space20
  • layui-col-space22
  • layui-col-space24
  • layui-col-space25
  • layui-col-space26
  • layui-col-space28
  • layui-col-space30
    支持列之间为 1px-30px 区间的所有双数间隔,以及 1px、5px、15px、25px 的单数间隔

下面是一个简单的例子,列间距为10px:

        <h3>列边距</h3><div class="layui-row layui-col-space10" ><div class="layui-col-md4" style="height: 50px"><div style="background-color:darkviolet;height: 50px">4</div></div><div class="layui-col-md4" style="height: 50px"><div style="background-color:darkcyan;height: 50px">4</div></div><div class="layui-col-md4" style="height: 50px"><div style="background-color:#00F7DE;height: 50px">4</div></div></div>

在这里插入图片描述
如果需要的间距高于30px(一般不常见),请采用偏移。

列偏移

对列追加 类似 layui-col-md-offset* 的预设类,从而让列向右偏移。其中 * 号代表的是偏移占据的列数,可选中为 1 - 12。
如:layui-col-md-offset3,即代表在“中型桌面屏幕”下,让该列向右偏移 3 个列宽度。
下面是一个采用「列偏移」机制让两个列左右对齐的实例

        <h3>列偏移</h3><div class="layui-row"><div class="layui-col-md4" style="background-color:green;height: 50px">4/12</div><div class="layui-col-md4 layui-col-md-offset4"style="background-color:green;height: 50px">偏移4列,从而在最右</div></div>

在这里插入图片描述
请注意,列偏移可针对不同屏幕的标准进行设定,比如上述的例子,只会在桌面屏幕下有效,当低于桌面屏幕的规定的临界值,就会堆叠排列。

栅格嵌套

理论上,你可以对栅格进行无穷层次的嵌套,这更加增强了栅格的表现能力。而嵌套的使用非常简单。在列元素(layui-col-md*)中插入一个行元素(layui-row),即可完成嵌套。下面是一个简单的例子:

        <h3>栅格嵌套</h3><div class="layui-row layui-col-space5"><div class="layui-col-md5" style="background-color:deepskyblue;height: 110px"><div class="layui-row grid-demo"><div class="layui-col-md3" style="background-color:deeppink;height: 50px">内部列</div><div class="layui-col-md9" style="background-color:mediumblue;height: 50px">内部列</div><div class="layui-col-md12" style="background-color:orchid;height: 50px">内部列</div></div></div><div class="layui-col-md7" style="background-color:deepskyblue;height: 110px"><div class="layui-row grid-demo grid-demo-bg1"><div class="layui-col-md12" style="background-color:mediumspringgreen;height: 50px">内部列</div><div class="layui-col-md9" style="background-color:deeppink;height: 50px">内部列</div><div class="layui-col-md3" style="background-color:mediumblue;height: 50px">内部列</div></div></div></div>

在这里插入图片描述

让IE8/9兼容栅格

事实上IE8和IE9并不支持媒体查询(Media Queries),但你可以使用下面的补丁完美兼容!该补丁来自于开源社区:

<!-- 让IE8/9支持媒体查询,从而兼容栅格 -->
<!--[if lt IE 9]><script src="https://cdn.staticfile.org/html5shiv/r29/html5.min.js"></script><script src="https://cdn.staticfile.org/respond.js/1.4.2/respond.min.js"></script>
<![endif]-->

将上述代码放入你页面 标签内的任意位置

  • 管理系统界面布局
    layui 之所以赢得如此多人的青睐,更多是在于它「前后界面兼备」的能力。既可编织出绚丽的前台页面,又可满足繁杂的管理系统界面需求。layui 致力于让每一位开发者都能轻松搭建自己的管理界面。
<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"><title>layout 管理系统大布局 - Layui</title><link rel="stylesheet" href="./layui/css/layui.css">
</head>
<body>
<div class="layui-layout layui-layout-admin"><div class="layui-header"><div class="layui-logo layui-hide-xs layui-bg-black">layout demo</div><!-- 头部区域(可配合layui 已有的水平导航) --><ul class="layui-nav layui-layout-left"><!-- 移动端显示 --><li class="layui-nav-item layui-show-xs-inline-block layui-hide-sm" lay-header-event="menuLeft"><i class="layui-icon layui-icon-spread-left"></i></li><li class="layui-nav-item layui-hide-xs"><a href="">nav 1</a></li><li class="layui-nav-item layui-hide-xs"><a href="">nav 2</a></li><li class="layui-nav-item layui-hide-xs"><a href="">nav 3</a></li><li class="layui-nav-item"><a href="javascript:;">nav groups</a><dl class="layui-nav-child"><dd><a href="">menu 11</a></dd><dd><a href="">menu 22</a></dd><dd><a href="">menu 33</a></dd></dl></li></ul><ul class="layui-nav layui-layout-right"><li class="layui-nav-item layui-hide layui-show-md-inline-block"><a href="javascript:;"><img src="//tva1.sinaimg.cn/crop.0.0.118.118.180/5db11ff4gw1e77d3nqrv8j203b03cweg.jpg" class="layui-nav-img">tester</a><dl class="layui-nav-child"><dd><a href="">Your Profile</a></dd><dd><a href="">Settings</a></dd><dd><a href="">Sign out</a></dd></dl></li><li class="layui-nav-item" lay-header-event="menuRight" lay-unselect><a href="javascript:;"><i class="layui-icon layui-icon-more-vertical"></i></a></li></ul></div><div class="layui-side layui-bg-black"><div class="layui-side-scroll"><!-- 左侧导航区域(可配合layui已有的垂直导航) --><ul class="layui-nav layui-nav-tree" lay-filter="test"><li class="layui-nav-item layui-nav-itemed"><a class="" href="javascript:;">menu group 1</a><dl class="layui-nav-child"><dd><a href="javascript:;">menu 1</a></dd><dd><a href="javascript:;">menu 2</a></dd><dd><a href="javascript:;">menu 3</a></dd><dd><a href="">the links</a></dd></dl></li><li class="layui-nav-item"><a href="javascript:;">menu group 2</a><dl class="layui-nav-child"><dd><a href="javascript:;">list 1</a></dd><dd><a href="javascript:;">list 2</a></dd><dd><a href="">超链接</a></dd></dl></li><li class="layui-nav-item"><a href="javascript:;">click menu item</a></li><li class="layui-nav-item"><a href="">the links</a></li></ul></div></div><div class="layui-body"><!-- 内容主体区域 --><div style="padding: 15px;">内容主体区域。记得修改 layui.css 和 js 的路径</div></div><div class="layui-footer"><!-- 底部固定区域 -->底部固定区域</div>
</div>
<script src="./layui/layui.js"></script>
<script>//JSlayui.use(['element', 'layer', 'util'], function(){var element = layui.element,layer = layui.layer,util = layui.util,$ = layui.$;//头部事件util.event('lay-header-event', {//左侧菜单事件menuLeft: function(othis){layer.msg('展开左侧菜单的操作', {icon: 0});},menuRight: function(){layer.open({type: 1,content: '<div style="padding: 15px;">处理右侧面板的操作</div>',area: ['260px', '100%'],offset: 'rt' //右上角,anim: 5,shadeClose: true});}});});
</script>
</body>
</html>

在这里插入图片描述


http://chatgpt.dhexx.cn/article/PmDmOa86.shtml

相关文章

css form实例 用CSS实现表单form布局实例

用CSS实现表单form布局实例&#xff0c;css form实例 很多时候我们遇到Form表单&#xff0c;左边是文字标题&#xff0c;右边是表单input空&#xff0c;对于新手来说是非常麻烦的事&#xff0c;好了接下来我们将奉送一段 divcss 代码关于Form表单布局实例及源代码。 Css form…

antdesign-vue框架form表单布局

下拉框赋默认值 <a-form-item label"催单状态&#xff1a;"><a-selectv-decorator"[reminderStatus,{initialValue: $store.getters.enterpriseId ? 2 : 0}]"style"width:100%;"allowClear><a-select-option value"0"…

Layui框架:layui的格栅布局规则

1、划分layui区域 layui-container&#xff1a;layui框架的容器&#xff0c;作用类似于flex布局的容器。 <div class"layui-container">// 在网页上划分一个区域&#xff0c;该区域专门使用layui的布局模块 </div> 在layui框架中&#xff0c;任何行上方…

layui框架学习(9:静态表格)

Layui中处理表格样式分为静态表格及数据表格&#xff0c;所谓静态表格是指数据固定的表格&#xff0c;而数据表格则是动态获取数据构建的表格&#xff0c;前者主要使用Layui的预设类及属性设置表格样式&#xff0c;而后者则主要调用table模块操作表格。本文主要学习Layui中与静…

关于layui框架的form表单布局

form表单的使用 在使用from表单的时候&#xff0c;必须先声明from模块&#xff0c;否则select、checkbox、radio等将无法显示&#xff0c;并且无法使用form相关功能&#xff0c;这是很多小白一开始经常犯的错误&#xff0c;虽然这很简单但也很基础&#xff0c;所以有必要在这里…

关于layui框架的form表单布局(小白向)

form表单的使用 在使用form表单的时候&#xff0c;必须先声明form模块&#xff0c;否则select、checkbox、radio等将无法显示&#xff0c;并且无法使用form相关功能&#xff0c;这是很多小白一开始经常犯的错误&#xff0c;虽然这很简单但也很基础&#xff0c;所以有必要在这里…

北斗/GPS差分定位技术有哪些?

普通的单点定位技术由于卫星信号在空间传播受到电离层、对流层等影响&#xff0c;信号传播发生了一定的折射&#xff0c;带来了伪据观测误差&#xff0c;使得定位精度在5到10米范围内。很显然这样的定位精度很难满足一些特定领域的需求。差分定位技术可以有效的提高定位精度&am…

5G+北斗:人员定位系统为化工厂定位赋能

人员定位系统是集计算机软硬件、信息采集处理、无线数据传输、网络数据通讯、自动控制等技术多学科综合应用为一体的自动识别信息技术产品&#xff0c;可以实现对不同人、物在不同状态下的智能识别。 物联网时代&#xff0c;人们以感知为目的实现人与人、人与物、物与物全面互联…

北斗与GPS有哪些区别?

北斗卫星建设是中国战略事业重要的一环。当然&#xff0c;国防安全是建设北斗最重要的原因。在地理信息如此重要的战场&#xff0c;必须握有自己的知识技术产权和产品。虽说GPS的民用在中国是免费的&#xff0c;但是如果战时美国关闭或者利用其“SA政策”对GPS“做手脚”&#…

常用的北斗高精度定位技术有哪些?

主要有&#xff1a;载波相位差分技术RTK、精密单点定位技术PPP、辅助北斗快速定位技术A-BDS、北斗地基增强系统、北斗星基增强系统这5项技术。 载波相位差分技术RTK 载波相位动态实时接收机RTK&#xff1a;Real - Time Kinematic&#xff0c;其原理是&#xff1a; 基准站和移…

什么是5G北斗RTK差分定位系统?它有哪些优势和应用领域?

5G技术的普及和应用&#xff0c;使得物联网和智能设备的使用越来越广泛。然而&#xff0c;在实际应用过程中&#xff0c;精准的定位数据是必不可少的。北斗差分定位系统作为一项定位技术&#xff0c;受到了市场的关注。本文将对5G北斗差分定位系统进行分析&#xff0c;并比较其…

北斗系统基础知识1(北斗系统定位原理说明“图文详述”)

需求说明&#xff1a;知识储备 内容 &#xff1a;北斗系统起源及工作原理 来自 &#xff1a;时间的诗 原文&#xff1a;http://www.bingdun.com/news/bingdun/3252.htm 从来没有那个事物像 GPS 那样改变了人类的生活&#xff0c;你能想象没有 GPS 的生活情境吗&am…

北斗通信模块 北斗gps模块 北斗通信终端DTU

计讯物联北斗通信模块DTU&#xff0c;支持北斗、三大运营商4G/3G/2G网络无线通信&#xff0c;采用高性能的工业级32位通信处理器&#xff0c;软件多级检测和硬件多重保护机制来提高设备稳定性。帮助用户快速接入高速互联网&#xff0c;实现安全可靠的数据传输&#xff0c;广泛应…

“北斗”知多少?

【日志】 2020/5/23 我想写一篇有关北斗的科普性的博客&#xff0c;将自己学到的东西做点小笔记&#xff0c;顺带分享给大家&#xff0c;嘿嘿。但是&#xff0c;一时间思潮翻涌&#xff0c;竟不知从何处开始写起。先开个草稿&#xff0c;之后萌生灵感再来填坑。 2020/6/23 今天…

ATK-S1216F8-BD GPS/北斗模块调试

手头上有这一模块。 1、模块通过串口与外部系统连接&#xff0c;串口波特率支持 4800、9600、19200、38400&#xff08;默认&#xff09;、57600、115200、230400 等不同速率&#xff0c; 2、兼容 5V/3.3V 单片机系统 3、 模块自带可充电后备电池&#xff0c;可以掉电保持星历…

【定位导航科普篇】北斗卫星导航技术介绍

1、中国北斗卫星导航系统-BDS 北斗卫星导航系统&#xff08;简称北斗系统&#xff09;是我国自主发展、独立运行的全球卫星导航系统&#xff0c;为全球用户提供全天候、全天时、高精度的定位、导航和授时服务&#xff0c;是继 GPS、GLONASS 之后&#xff0c;第三个成熟的卫星导…

北斗系统概述

目录 1 空间段 2 地面控制段 3 用户段 4 时间系统 我国制定了北斗卫星导航系统三步走战略&#xff1a;第一阶段&#xff0c;2000年年底&#xff0c;发射2颗北斗一号卫星&#xff0c;建成北斗一号系统&#xff0c;向中国提供服务&#xff1b;第二阶段&#xff0c;2007年-201…

室外定位:高精度北斗RTK定位技术

北斗RTK定位技术&#xff0c;也称北斗差分定位技术&#xff0c;利用我国自主研发的北斗卫星定位系统实现精确定位功能。定位精度可根据需要&#xff0c;通过选择不同精度的人员定位终端来实现。 在科技强国的战略驱动下&#xff0c;北斗RTK定位技术迎来了广阔的发展机遇&#x…

北斗定位模块是什么,有定位功能吗

我国北斗定位系统的组网完成&#xff0c;其衍生的应用技术和产业如雨后春笋&#xff0c;市场上也出现了越来越多的定位设备、定位模块等&#xff0c;显然这些设备的主要功能是定位&#xff0c;其他方面呢&#xff0c;究竟北斗定位模块是什么呢? 北斗定位模块 北斗定位模块&…

北斗三号卫星导航信号及接收策略

一、北斗三号卫星导航信号的特点 从上个世纪九十年代初北斗一号立项到现在&#xff0c;我国的北斗卫星导航系统已经走过了二十多年的发展历程。根据三步走的发展计划&#xff0c;先后经历了北斗一号和北斗二号两个阶段&#xff0c;目前正在向北斗三号发展。以用户的视角我们可…