当前位置: 首页 > news >正文

【Java 进阶篇】深入了解 Bootstrap 栅格系统

在这里插入图片描述

在网页开发中,创建响应式的布局是至关重要的,因为不同设备和屏幕尺寸需要不同的布局来呈现内容。Bootstrap 提供了一个强大的栅格系统,使开发者能够轻松创建适应不同屏幕的网页布局。本文将深入介绍 Bootstrap 栅格系统,面向初学者,帮助您充分了解如何使用它来构建响应式网页。

什么是 Bootstrap 栅格系统?

Bootstrap 栅格系统是一种基于12列网格的布局系统。这意味着您可以将页面划分为12个等宽的列,然后将内容放入这些列中。通过在不同的屏幕宽度上定义不同的列宽,您可以轻松创建响应式布局,以适应不同设备的屏幕大小,例如桌面、平板和手机。

栅格系统的核心思想是将页面划分为行(row)和列(col)。每行可以包含一个或多个列,列的宽度总和不能超过12列。这使得网页布局变得非常灵活,同时确保内容在各种屏幕上以一致的方式呈现。

Bootstrap 栅格系统的基本结构

为了更好地理解 Bootstrap 栅格系统,让我们来看一个基本的示例。

<div class="container"><div class="row"><div class="col-sm-4"><!-- 内容1 --></div><div class="col-sm-4"><!-- 内容2 --></div><div class="col-sm-4"><!-- 内容3 --></div></div>
</div>

上述代码中,我们有一个容器(container)包含一个行(row),而行中包含了三列(col-sm-4)。现在,让我们逐步分解这个示例的关键部分:

  • container:容器是 Bootstrap 栅格系统的最外层包裹元素。它用于包含行(row)和列(col)以及其他内容。容器的作用是确保内容在不同屏幕尺寸上居中对齐,并提供一些内边距,以便内容不会触及屏幕的边缘。

  • row:行是一组列的容器。每行(row)在页面上都是水平排列的,可以包含一个或多个列(col)。行的主要作用是创建列的组合,使它们在同一水平线上对齐。

  • col-sm-4:列是页面的主要构建块,用于包含实际的内容。在这个示例中,我们使用了三个列,每个列占据了4个网格列的宽度,总和为12列。这是一种常见的布局,因为它适用于桌面屏幕,每个列都具有相同的宽度。col-sm-4 中的 “sm” 表示响应式断点,即在小屏幕(如平板)上,每个列仍然占据4列。

响应式设计和断点

Bootstrap 栅格系统的一个强大之处在于它支持响应式设计,这意味着您可以根据屏幕宽度自动调整布局。Bootstrap 使用断点(breakpoint)来定义不同屏幕尺寸上的列宽。

以下是 Bootstrap 的一些常见断点:

  • sm(小屏幕):用于平板和较小的桌面屏幕。
  • md(中等屏幕):用于普通桌面屏幕。
  • lg(大屏幕):用于大型桌面屏幕。
  • xl(特大屏幕):用于非常大的屏幕。

通过在列的类名中添加适当的断点前缀,您可以指定在不同屏幕尺寸上列的宽度。例如,col-sm-4 表示在小屏幕上每个列占据4列,而 col-md-6 表示在中等屏幕上每个列占据6列。

让我们看一个使用不同断点的示例,以便更好地理解:

<div class="container"><div class="row"><div class="col-md-6 col-lg-4"><!-- 列1 --></div><div class="col-md-6 col-lg-4"><!-- 列2 --></div><div class="col-lg-4"><!-- 列3(仅在大屏幕上显示) --></div></div>
</div>

在这个示例中,我们有三列,每列都根据不同的断点设置了不同的宽度。前两列在中等屏幕上占据6列,在大屏幕上占据4列。最后一列只在大屏幕上显示,占据4列。

列偏移和偏移量

有时候,您可能希望在列之间创建一些空白,或将列向右移动。Bootstrap 提供了列偏移(offset)类,可以帮助您实现这些效果。

以下是一个示例,展示如何使用列偏移来在列之间创建空白:

<div class="container"><div class="row"><div class="col-md-4"><!-- 列1 --></div><div class="col-md-4"><!-- 列2 --></div><div class="col-md-4"><!-- 列3 --></div></div><div class="row"><div class="col-md-3"><!-- 列1 --></div><div class="col-md-3 offset-md-3"><!-- 列2(偏移3列宽度) --></div><div class="col-md-3"><!-- 列3 --></div></div>
</div>

在这个示例中,我们创建了两行,每行包含三列。在第二行的第二列上,我们使用了 offset-md-3 类来向右偏移3列的宽度,从而在列2和列3之间创建了空白。

列的排序

有时,您可能希望在不同屏幕尺寸上重新排列列的顺序。Bootstrap 允许您使用列排序(order)类来轻松实现这一点。

以下是一个示例,展示如何使用列排序类来更改列的显示顺序:

<div class="container"><div class="row"><div class="col-md-4 order-2"><!-- 列1(在大屏幕上显示在列2之后) --></div><div class="col-md-4 order-1"><!-- 列2(在大屏幕上显示在列1之前) --></div><div class="col-md-4"><!-- 列3 --></div></div>
</div>

在这个示例中,我们使用了 order-2order-1 类来指定列1和列2在大屏幕上的显示顺序。列1会显示在列2之后,而列2会显示在列1之前,而列3则保持不变。

制作嵌套布局

Bootstrap 栅格系统也支持嵌套布局,这意味着您可以在列中创建更多的行和列,以构建更复杂的布局。这对于构建复杂的页面非常有用。

以下是一个示例,展示如何创建嵌套布局:

<div class="container"><div class="row"><div class="col-md-6"><!-- 列1 --></div><div class="col-md-6"><!-- 列2 --></div></div><div class="row"><div class="col-md-4"><!-- 列3 --></div><div class="col-md-4"><!-- 列4 --></div><div class="col-md-4"><!-- 列5 --></div></div>
</div>

在这个示例中,我们首先创建了一个包含两列的行,然后在第二行中创建了另一个包含三列的行。这种嵌套布局的方式可以帮助您更灵活地控制页面的结构。

自定义栅格系统

如果您希望创建自定义的栅格系统,而不仅仅使用Bootstrap的默认样式,您也可以使用Bootstrap的Sass版本或Less版本,以便更灵活地定义栅格系统的参数,例如列数、断点、列宽等。

以下是一个使用Sass版本的示例,展示如何自定义栅格系统的列数:

// 定义列数
$grid-columns: 16;// 定义列宽
$grid-gutter-width: 30px;
$grid-row-gutter-width: 15px;// 导入Bootstrap的Sass文件
@import "bootstrap/bootstrap";

在这个示例中,我们通过设置 $grid-columns 变量来定义列数,然后可以根据需要自定义其他参数。这样,您可以创建符合项目需求的自定义栅格系统。

结语

Bootstrap 栅格系统是网页开发的强大工具,使创建响应式布局变得容易。无论您是初学者还是有经验的开发者,掌握栅格系统是非常重要的,因为它是构建现代网页和Web应用程序的基础。希望本文能够帮助您更好地理解和使用Bootstrap的栅格系统,以创建出美观且响应式的网页布局。愿您在网页开发中取得成功!

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

相关文章:

【Java 进阶篇】深入了解 Bootstrap 栅格系统

在网页开发中&#xff0c;创建响应式的布局是至关重要的&#xff0c;因为不同设备和屏幕尺寸需要不同的布局来呈现内容。Bootstrap 提供了一个强大的栅格系统&#xff0c;使开发者能够轻松创建适应不同屏幕的网页布局。本文将深入介绍 Bootstrap 栅格系统&#xff0c;面向初学者…...

Gradle中的buildScript代码块

PS: 在build script中的task apply plugin: spring-boot 需要 classpath("org.springframework.boot:spring-boot-gradle-plugin:1.2.3.RELEASE") apply plugin: com.moowork.gulp 需要classpath com.moowork.gradle:gradle-gulp-plugin:0.10 在编写Gradle脚本的时…...

Spring boot 集成 xxl-job

文章目录 xxl-job 简介引入xxl-job依赖配置xxl-job config添加properties文件配置BEAN模式&#xff08;方法形式&#xff09;步骤一&#xff1a;执行器项目中&#xff0c;开发Job方法&#xff1a;步骤二&#xff1a;调度中心&#xff0c;新建调度任务 xxl-job 简介 官网:https:…...

uni-app通过 vuedraggable 创建上下拖动排序组件

我们右键项目 选择 使用命令行窗口打开所在目录 然后 在终端中输入 npm install vuedraggable --save导入 vuedraggable 然后组件编写代码如下 <template><view class"container"><draggable v-model"list" :options"dragOptions&…...

Android高版本读取沙盒目录apk解析安装失败解决方案

bug场景&#xff1a; 应用内升级下载apk完成后安装&#xff0c;vivo&#xff08;Android13&#xff09;手机会报解析包错误&#xff0c;7.0及以上的手机是没问题的。开始以为是v1,v2签名问题导致的&#xff0c;但是我用浏览器下载下来的安装包是能够正确安装的。排除v1,v2签名的…...

ddns-go配合aliyun域名解析通过ipv6实现共享桌面

ddns-go配合aliyun域名解析通过ipv6实现共享桌面 前提&#xff1a; 必须拥有ipv6公网IP&#xff0c;测试IPv6 测试 (testipv6.cn) 如果是光猫拨号一点要选择ipv4和ipv6&#xff0c;同时要看光猫是否支持ipv6转发&#xff0c;如果不支持转发也不行&#xff0c;光猫不支持ipv6…...

C#WPF 应用Grid布局实现用户登录实例

本文介绍C#WPF Grid布局应用实例,通过用户登录实例演示掌握Grid布局用法。 目录 一、Grid面板介绍 二、用户登录实例 一、Grid面板介绍 网格面板是所有面板中最复杂但用途最广泛的面板。网格面板可用于设计复杂的用户界面,我们需要将多个元素以行和列的表格格式放置。 WP…...

RHEL 8.6 Kubespray 1.23.0 install kubernetes v1.27.5

文章目录 1. 预备条件2. download01 节点 安装 dockerdownload01 节点 介质下载下载 bastion01节点配置 yum 源bastion01 节点安装 docker5. 安装 docker insecure registrybastion01 部署 nginx 与 镜像入库13.1 配置 config.sh13.2 配置 setup-docker.sh13.3 配置 start-ngin…...

RGBD Salient Object Detection via Disentangled Cross-Modal Fusion

方法 HHA means “horizontal disparity, height above ground, and angle with gravity”.结构化上下文编码器{E R S _R^S RS​,E D S _D^S DS​}&#xff0c;模态特定内容编码器{E R C _R^C RC​,E D C _D^C DC​} 体会 作者未提供代码...

VMware下linux中ping报错unknown host的解决办法

一、错误截图 二、解决办法 2.1 按照步骤查看本机虚拟IP 依次点击&#xff1a;【编辑】》【虚拟网络编辑器】&#xff0c;选中NET模式所属的行&#xff0c;就能看到子网地址。 比喻&#xff0c;我的子网地址是&#xff1a;192.168.18.0 那么&#xff0c;接下来要配置的linux…...

Macos数据库管理:Navicat Premium 中文

Navicat Premium提供了直观且易用的图形用户界面&#xff0c;使得操作更为便捷。Navicat Premium 中文支持多种数据库系统&#xff0c;如MySQL、MariaDB、Oracle、SQLite、PostgreSQL等&#xff0c;可以让用户在同一平台上管理不同类型的数据库。Navicat Premium拥有强大的数据…...

数据结构 - 7(Map和Set 15000字详解)

一&#xff1a; 二叉搜索树 1.1 二叉搜索树的概念 概念 二叉搜索树又称二叉排序树&#xff0c;它或者是一棵空树&#xff0c;或者是具有以下性质的二叉树: 若它的左子树不为空&#xff0c;则左子树上所有节点的值都小于根节点的值若它的右子树不为空&#xff0c;则右子树上所…...

windows 11 安装PHP8.2

环境说明 windows:windows 11 x64apache: Apache/2.4.43php :php-8.2.11 一.php 1、PHP下载 PHP For Windows: Binaries and sources Releases 注意&#xff1a; 1.要下载Thread Safe&#xff0c;否则没有php8apache2_4.dll这个文件&#xff1b;如果使用Apache作为服务器…...

计算机网络学习笔记(三):数据链路层(待更新)

目录 3.1 基本概念 3.1.1 数据链路和帧 3.1.2 三个基本问题 3.2 类型1&#xff1a;使用点对点信道的数据链路层&#xff08;路由器&#xff09; 3.2.1 点对点协议 PPP&#xff1a;特点 3.2.2 点对点协议 PPP&#xff1a;帧格式 3.2.3 点对点协议 PPP&#xff1a;工作状态 …...

hbase操作学习

1.namespace list_namespace 展示数据库 create_namespace 可以带属性名 属性值 create_namespace mydb,{author>hjp,ctime>2023-10-18}describe_namespace ‘库名’ 查看库的详细信息 alter_namespace ‘库名’ 修改表的详细信息 删除就是把method设置为unset dr…...

Nginx详细配置指南

nginx.conf配置 找到Nginx的安装目录下的nginx.conf文件&#xff0c;该文件负责Nginx的基础功能配置。 配置文件概述 Nginx的主配置文件(conf/nginx.conf)按以下结构组织&#xff1a; 配置块功能描述全局块与Nginx运行相关的全局设置events块与网络连接有关的设置http块代理…...

【数据库】SQL 过滤数据

过滤数据 简单过滤where 子句操作符检查单个值范围值检擦空值检查 高级过滤多个过滤条件求值顺序IN 操作符NOT 操作符 在 s q l sql sql 语句中&#xff0c;通过 WHERE 子句指定搜索条件进行过滤。 简单过滤 包含&#xff1a;WHERE&#xff0c;BETWEEN&#xff0c;IS NULL&a…...

缓存相关问题

对于缓存&#xff0c;我们主要关心两个&#xff1a;缓存的命中率&#xff0c;数据的一致性。由此又会有一些缓存引起的问题&#xff0c;缓存击穿、穿透、雪崩。对于这些问题也是我们在使用缓存时不得不考虑的 。这些问题的解决方案也有很多。这里简单列举几个&#xff1a; &am…...

arrow(c++)改写empyrical系列1---用arrow读取基金净值数据并计算夏普率

用arrow c版本读取了csv中的基金净值数据&#xff0c;然后计算了夏普率&#xff0c;比较尴尬的是&#xff0c;arrow c版本计算耗费的时间却比python的empyrical版本耗费时间多。。。 arrow新手上路&#xff0c;第一次自己去实现功能&#xff0c;实现的大概率并不是最高效的方…...

Mathematica强制将函数的自变量由符号转为数值

问题 使用Mathematcia完成函数优化&#xff08;FindMaximum&#xff09;十分方便。但是如果优化的目标函数非常复杂&#xff0c;里面嵌套了若干NSolve函数&#xff0c;那么FindMaximum可能会计算非常长时间&#xff0c;甚至无法得到正确结果。 原因在于&#xff0c;Mathemtic…...

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…...

【力扣数据库知识手册笔记】索引

索引 索引的优缺点 优点1. 通过创建唯一性索引&#xff0c;可以保证数据库表中每一行数据的唯一性。2. 可以加快数据的检索速度&#xff08;创建索引的主要原因&#xff09;。3. 可以加速表和表之间的连接&#xff0c;实现数据的参考完整性。4. 可以在查询过程中&#xff0c;…...

智能在线客服平台:数字化时代企业连接用户的 AI 中枢

随着互联网技术的飞速发展&#xff0c;消费者期望能够随时随地与企业进行交流。在线客服平台作为连接企业与客户的重要桥梁&#xff0c;不仅优化了客户体验&#xff0c;还提升了企业的服务效率和市场竞争力。本文将探讨在线客服平台的重要性、技术进展、实际应用&#xff0c;并…...

【AI学习】三、AI算法中的向量

在人工智能&#xff08;AI&#xff09;算法中&#xff0c;向量&#xff08;Vector&#xff09;是一种将现实世界中的数据&#xff08;如图像、文本、音频等&#xff09;转化为计算机可处理的数值型特征表示的工具。它是连接人类认知&#xff08;如语义、视觉特征&#xff09;与…...

ElasticSearch搜索引擎之倒排索引及其底层算法

文章目录 一、搜索引擎1、什么是搜索引擎?2、搜索引擎的分类3、常用的搜索引擎4、搜索引擎的特点二、倒排索引1、简介2、为什么倒排索引不用B+树1.创建时间长,文件大。2.其次,树深,IO次数可怕。3.索引可能会失效。4.精准度差。三. 倒排索引四、算法1、Term Index的算法2、 …...

NFT模式:数字资产确权与链游经济系统构建

NFT模式&#xff1a;数字资产确权与链游经济系统构建 ——从技术架构到可持续生态的范式革命 一、确权技术革新&#xff1a;构建可信数字资产基石 1. 区块链底层架构的进化 跨链互操作协议&#xff1a;基于LayerZero协议实现以太坊、Solana等公链资产互通&#xff0c;通过零知…...

蓝桥杯3498 01串的熵

问题描述 对于一个长度为 23333333的 01 串, 如果其信息熵为 11625907.5798&#xff0c; 且 0 出现次数比 1 少, 那么这个 01 串中 0 出现了多少次? #include<iostream> #include<cmath> using namespace std;int n 23333333;int main() {//枚举 0 出现的次数//因…...

在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?

uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件&#xff0c;用于在原生应用中加载 HTML 页面&#xff1a; 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...

关键领域软件测试的突围之路:如何破解安全与效率的平衡难题

在数字化浪潮席卷全球的今天&#xff0c;软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件&#xff0c;这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下&#xff0c;实现高效测试与快速迭代&#xff1f;这一命题正考验着…...

Python网页自动化Selenium中文文档

1. 安装 1.1. 安装 Selenium Python bindings 提供了一个简单的API&#xff0c;让你使用Selenium WebDriver来编写功能/校验测试。 通过Selenium Python的API&#xff0c;你可以非常直观的使用Selenium WebDriver的所有功能。 Selenium Python bindings 使用非常简洁方便的A…...