Linux 中的逻辑卷 LVM 管理完整初学者指南

linux 中的逻辑卷 lvm 管理完整初学者指南

这是 Linux 中 LVM(逻辑卷管理)的完整初学者指南。

在本教程中,您将了解 LVM 的概念、它的组件以及为什么要使用它。

我不会仅限于理论上的解释,我还将展示在 Linux 中创建和管理 LVM 的动手示例。

简而言之,我将为您提供在现实世界中开始使用 LVM 所需的所有必要信息。

Linux 中的 LVM 是什么?

LVM 代表逻辑卷管理。这是管理存储系统的另一种方法,而不是传统的基于分区的方法。在 LVM 中,您无需创建分区,而是创建逻辑卷,然后您可以像挂载磁盘分区一样轻松地将这些卷挂载到文件系统中。

LVM 的组件

LVM 包含三个主要组件:

物理卷卷组逻辑卷

尽管该列表由三个部分组成,但其中只有两个是分区系统的直接对应部分,下表记录了这一点。

代码语言:txt复制

磁盘分区系统      LVM  分区          逻辑卷  磁盘           卷组

物理卷没有任何直接对应物,但我很快就会谈到这一点。

为什么要使用 LVM?

LVM 的主要优点是调整卷或卷组的大小非常容易。它抽象出了所有丑陋的部分(分区、原始磁盘),并为我们留下了一个中央存储池可供使用。

如果您曾经经历过分区大小调整的恐惧,那么您会想要使用 LVM。

动手实验室准备

这篇文章不仅仅是理论。在此过程中,我将展示实际的命令示例,学习某些东西的最佳方法是亲身实践。为此,我建议您使用虚拟机。

为了帮助你,我已经准备了一个简单的 Vagrantfile,你可以用它来用 VirtualBox 启动一个非常轻量级的虚拟机。此虚拟机具有三个额外的磁盘,您和我可以将它们用于下面的命令示例。

在文件系统的某处创建一个目录,并将以下内容保存在该文件中,名为Vagrantfile.

代码语言:txt复制

Vagrant.configure "2" do |config|    config.vm.box = "ubuntu/focal64"    config.vm.hostname = "lvm"    3.times {|i| config.vm.disk :disk, size: "5GB", name: "drive-#{i}"}    config.vm.provider :virtualbox do |machine|        machine.memory = 1024        machine.cpus = 1        machine.customize ["modifyvm", :id, "--cpuexecutioncap", "50"]    endend# vi: set ft=ruby

或者,如果您愿意,可以使用wget或curl从我的 gist 下载文件。

代码语言:txt复制

wget https://gist.githubusercontent.com/debdutdeb/98ed1b6aef36885d07ce8247188dfd5e/raw/524259da5dfa2d8750883d01c8159829729e224d/Vagrantfile

确保你安装了Vagrant和VirtualBox。

一旦 Vagrantfile 就位,将环境变量设置VAGRANT_EXPERIMENTAL为disks.

代码语言:txt复制

export VAGRANT_EXPERIMENTAL=disks

最后,使用以下命令启动虚拟机(确保您与 Vagrantfile 位于同一目录中):

代码语言:txt复制

vagrant up

机器运行后,您可以使用vagrant sshSSH 连接到它并运行本文中的示例命令。

完成后请记住vagrant destroy从与 Vagrantfile 相同的目录运行。

安装 LVM

在您可以使用任何命令之前,您需要安装该lvm2软件包。这应该预装在大多数现代发行版中,尤其是基于 Ubuntu 的发行版中。但是,在继续之前,我不得不提到这一点。要安装lvm2,请查阅您的发行版的文档。

LVM 实践

对于这个动手演练,我构建了一个具有 40G 根存储(不重要)和三个大小为 5G 的外部磁盘的虚拟机。这些磁盘的大小是任意的。

代码语言:txt复制

vagrant@lvm:~$ lsblk -o name,size,fstypeNAME    SIZE FSTYPEloop0  55.5M squashfsloop1  32.3M squashfsloop2  70.4M squashfssda      40G └─sda1   40G ext4sdb      10M iso9660sdc       5G sdd       5G sde       5G

如您所见,我将使用的设备sdc是sdd和sde。

还记得我告诉过你 LVM 包含三个主要组件吗?

物理卷卷组逻辑卷

是时候一一见他们了。

1. 物理卷

关于 LVM,您首先需要了解的是物理卷。物理卷是用于实现抽象即逻辑卷的原材料或构建块。简单来说,物理卷是 LVM 系统的逻辑单元。

物理卷可以是任何东西,原始磁盘或磁盘分区。创建和初始化物理卷是一回事。两者都意味着您只是在为进一步的操作准备构建块(即分区、磁盘)。这将在瞬间变得更加清晰。

实用程序:pv所有管理物理卷的实用程序都以P hysical Volume的字母开头。例如pvcreate, pvchange,pvs等pvdisplay。

创建物理卷

您可以使用原始未分区磁盘或分区本身来创建物理卷。

正如我之前提到的,我的虚拟机连接了三个外部驱动器,让我们从/dev/sdc.

我们使用pvcreate命令来创建物理卷。只需将设备名称传递给它即可。

代码语言:txt复制

sudo pvcreate /dev/sdc

你应该看到这样的东西:-

代码语言:txt复制

vagrant@lvm:~$ sudo pvcreate /dev/sdc  Physical volume "/dev/sdc" successfully created.

接下来我将/dev/sdd分成相等的部分。使用任何工具cfdisk,,,等parted,fdisk有很多工具可以完成这项工作。

代码语言:txt复制

vagrant@lvm:~$ lsblk -o name,size,fstype | grep sddsdd       5G ├─sdd1  2.5G └─sdd2  2.5G

您现在可以在一个步骤中从这两个分区中快速创建另外两个物理卷,同时将这两个设备传递给pvcreate。

代码语言:txt复制

sudo pvcreate /dev/sdd1 /dev/sdd2

看一看:-

代码语言:txt复制

vagrant@lvm:~$ sudo pvcreate /dev/sdd1 /dev/sdd2  Physical volume "/dev/sdd1" successfully created.  Physical volume "/dev/sdd2" successfully created.

列出可用的物理卷

您可以使用三个命令来获取可用物理卷的列表pvscan,pvs和pvdisplay。您通常不需要向这些命令传递任何内容。

pvscan:-

代码语言:txt复制

vagrant@lvm:~$ sudo pvscan  PV /dev/sdc                       lvm2 [5.00 GiB]  PV /dev/sdd1                      lvm2 [2.50 GiB]  PV /dev/sdd2                      lvm2 [<2.50 GiB]  Total: 3 [<10.00 GiB] / in use: 0 [0   ] / in no VG: 3 [<10.00 GiB]

pvs:-

代码语言:txt复制

vagrant@lvm:~$ sudo pvs  PV         VG Fmt  Attr PSize  PFree   /dev/sdc      lvm2 ---   5.00g  5.00g  /dev/sdd1     lvm2 ---   2.50g  2.50g  /dev/sdd2     lvm2 ---  <2.50g <2.50g

pvdisplay:-

代码语言:txt复制

vagrant@lvm:~$ sudo pvdisplay  "/dev/sdc" is a new physical volume of "5.00 GiB"  --- NEW Physical volume ---  PV Name               /dev/sdc  VG Name                 PV Size               5.00 GiB  Allocatable           NO  PE Size               0     Total PE              0  Free PE               0  Allocated PE          0  PV UUID               SzSkdD-xKYa-4y7P-teyU-481p-uiQ8-qieMJJ     "/dev/sdd1" is a new physical volume of "2.50 GiB"  --- NEW Physical volume ---  PV Name               /dev/sdd1  VG Name                 PV Size               2.50 GiB  Allocatable           NO  PE Size               0     Total PE              0  Free PE               0  Allocated PE          0  PV UUID               553Iy4-JJ21-LfIw-udtO-j9Cd-7gFS-iXXFVS     "/dev/sdd2" is a new physical volume of "<2.50 GiB"  --- NEW Physical volume ---  PV Name               /dev/sdd2  VG Name                 PV Size               <2.50 GiB  Allocatable           NO  PE Size               0     Total PE              0  Free PE               0  Allocated PE          0  PV UUID               bf7ghn-QkPm-EUdp-GdyW-shMG-5sMn-VhNtYB

正如您所看到的,除了列出物理卷之外,这些命令还为您提供了大量有关这些卷的其他信息。

删除物理卷

pvremove您可以使用该命令删除物理卷。就像pvcreate,只需将设备(初始化为物理卷)传递给pvremove命令。

为了演示,我将从/dev/sdd2列表中删除。

代码语言:txt复制

sudo pvremove /dev/sdd2

输出应与此相同:-

代码语言:txt复制

vagrant@lvm:~$ sudo pvremove /dev/sdd2  Labels on physical volume "/dev/sdd2" successfully wiped.

现在列出物理卷sudo pvs

代码语言:txt复制

vagrant@lvm:~$ sudo pvs  PV         VG Fmt  Attr PSize PFree  /dev/sdc      lvm2 ---  5.00g 5.00g  /dev/sdd1     lvm2 ---  2.50g 2.50g

/dev/sdd2不再在这里。

2. 卷组

卷组是物理卷的集合。它是 LVM 中的下一个抽象级别。卷组是结合了多个原始存储设备的存储容量的存储池。

实用程序:所有卷组实用程序名称都以 开头vg,代表卷组,例如、等。vgcreatevgsvgrename

创建卷组

卷组是使用该vgcreate命令创建的。的第一个参数vgcreate是您要为该卷组指定的名称,其余的是要支持存储池的物理卷的列表。

代码语言:txt复制

sudo vgcreate lvm_tutorial /dev/sdc /dev/sdd1

例子:-

代码语言:txt复制

vagrant@lvm:~$ sudo vgcreate lvm_tutorial /dev/sdc /dev/sdd1  Volume group "lvm_tutorial" successfully created

列出卷组

列出卷组类似于列出物理卷,您可以使用具有不同详细级别的不同命令vgdisplay、vgscan和vgs。

我个人更喜欢vgs命令,sudo vgs

沁言学术 沁言学术

你的论文写作AI助理,永久免费文献管理工具,认准沁言学术

沁言学术 30 查看详情 沁言学术 代码语言:txt复制

vagrant@lvm:~$ sudo vgs  VG           #PV #LV #SN Attr   VSize VFree  lvm_tutorial   2   0   0 wz--n- 7.49g 7.49gvgscan:-vagrant@lvm:~$ sudo vgscan  Found volume group "lvm_tutorial" using metadata type lvm2vgdisplay:-vagrant@lvm:~$ sudo vgdisplay   --- Volume group ---  VG Name               lvm_tutorial  System ID               Format                lvm2  Metadata Areas        2  Metadata Sequence No  1  VG Access             read/write  VG Status             resizable  MAX LV                0  Cur LV                0  Open LV               0  Max PV                0  Cur PV                2  Act PV                2  VG Size               7.49 GiB  PE Size               4.00 MiB  Total PE              1918  Alloc PE / Size       0 / 0     Free  PE / Size       1918 / 7.49 GiB  VG UUID               LYVE9P-vY0G-OAW6-an8q-yfBx-rrB1-YU61m1

列出附加到卷组的物理卷

您可以使用以下命令列出连接到特定卷组的所有物理卷:-

代码语言:txt复制

sudo pvdisplay -S vgname= -C -o pv_name

例子:-

代码语言:txt复制

vagrant@lvm:~$ sudo pvdisplay -S vgname=lvm_tutorial -C -o pv_name  PV          /dev/sdc    /dev/sdd1

您还可以获得物理卷的计数。

代码语言:txt复制

sudo vgdisplay -S vgname= -C -o pv_count

例子:-

代码语言:txt复制

vagrant@lvm:~$ sudo vgdisplay -S vgname=lvm_tutorial -C -o pv_count  #PV    3

扩展卷组

扩展卷组意味着向卷组添加额外的物理卷。为此,vgextend使用该命令。语法很简单:-

代码语言:txt复制

vgextend    ....

让我们将lvm_tutorial音量扩大/dev/sdd2.

代码语言:txt复制

sudo vgextend lvm_tutorial /dev/sdd2

专注于输出:-

代码语言:txt复制

vagrant@lvm:~$ sudo vgextend lvm_tutorial /dev/sdd2  Physical volume "/dev/sdd2" successfully created.  Volume group "lvm_tutorial" successfully extended

在物理卷部分,我们最终将其/dev/sdd2作为物理卷删除,但必须将分区或原始磁盘初始化为物理卷,否则 LVM 将无法将其作为卷组的一部分进行管理。所以在将它添加到卷组之前vgextend做好准备。/dev/sdd2

现在列出附加到此卷组的物理卷,以确保安全。

代码语言:txt复制

sudo pvdisplay -S vgname=lvm_tutorial -C -o pv_name

输出:-

代码语言:txt复制

vagrant@lvm:~$ sudo pvdisplay -S vgname=lvm_tutorial -C -o pv_name  PV          /dev/sdc    /dev/sdd1   /dev/sdd2

/dev/sdd2现在按预期在列表中。

减少卷组

就像扩展一个卷组意味着添加另一个物理卷一样,减少它意味着删除一个或多个物理卷。

我们使用vgreduce命令来执行此操作。一般语法如下:-

代码语言:txt复制

vgreduce    ....

让我们删除物理卷/dev/sdc和/dev/sdd1.

代码语言:txt复制

sudo vgreduce lvm_tutorial /dev/sdc /dev/sdd1

例子:-

代码语言:txt复制

vagrant@lvm:~$ sudo vgreduce lvm_tutorial /dev/sdc /dev/sdd1  Removed "/dev/sdc" from volume group "lvm_tutorial"  Removed "/dev/sdd1" from volume group "lvm_tutorial"

再次列出物理卷。

代码语言:txt复制

sudo pvdisplay -S vgname=lvm_tutorial -C -o pv_name

输出:-

代码语言:txt复制

vagrant@lvm:~$ sudo pvdisplay -S vgname=lvm_tutorial -C -o pv_name  PV          /dev/sdd2

那两个物理卷不见了。

现在,为了本文的其余部分,将这两个物理卷添加回来。

代码语言:txt复制

sudo vgextend lvm_tutorial /dev/sdc /dev/sdd1

删除卷组

vgremove您可以使用该命令删除逻辑卷。

代码语言:txt复制

sudo vgremove lvm_tutorial

现在不要运行此命令,否则您必须重新创建卷组。如果您想对其进行测试,请在本文的最后运行它。

3. 逻辑卷

这是您将主要使用的内容。逻辑卷就像一个分区,但它不是位于原始磁盘之上,而是位于卷组之上。你可以,

使用您想要的任何文件系统格式化逻辑卷。将其挂载到您想要的文件系统中的任何位置。

在本节中,您将学习,

如何创建逻辑卷。对逻辑卷的常用操作。调整逻辑卷的大小。删除逻辑卷。

实用程序:所有卷组实用程序名称都以 开头lv,代表逻辑卷。例如, ,等等, ,等等lvcreatelvslvreducevgcreatevgsvgrename

创建逻辑卷

lvcreate使用该命令创建逻辑卷。常用的语法如下所示,

代码语言:txt复制

sudo lvcreate -L  -n  

-L选项用于新逻辑卷的大小,您可以使用任何以“GB”、“MB”或“KB”结尾的整数。例如“1GB”。-n选项用于命名此逻辑卷。需要将这个逻辑卷所属的卷组的名称传递给它,因此,在为逻辑卷提供大小时,请确保卷组有可用空间。

在虚拟机上运行以下命令:

代码语言:txt复制

sudo lvcreate -L 5GB -n lv1 lvm_tutorial

示例输出:

代码语言:txt复制

vagrant@lvm:~$ sudo lvcreate -L 5GB -n lv1 lvm_tutorial  Logical volume "lv1" created.

对逻辑卷的常用操作

正如我之前所说,您可以将文件系统放在逻辑卷上,也可以将其挂载到文件系统的任何位置。

/dev//创建后,您可以在路径中找到逻辑卷。例如,在我们的例子中,音量将在/dev/lvm_tutorial/lv1.

代码语言:txt复制

vagrant@lvm:~$ ls -l /dev/lvm_tutorial/lv1 lrwxrwxrwx 1 root root 7 May 17 02:09 /dev/lvm_tutorial/lv1 -> ../dm-0

现在您可以像使用任何分区一样使用它。用ext4格式化,

代码语言:txt复制

sudo mkfs.ext4 /dev/lvm_tutorial/lv1

将它安装在当前目录结构中的某个位置,例如/mnt,

代码语言:txt复制

sudo mount -t ext4 /dev/lvm_tutorial/lv1 /mnt

调整逻辑卷的大小

您可以使用命令扩展逻辑卷lvextend并使用命令减小其大小lvreduce。或者,您可以使用单个命令lvresize来完成这两项任务。

首先让我们看看卷组中是否还有剩余空间。

代码语言:txt复制

sudo vgs -S vgname=lvm_tutorial -o vg_free

输出:-

代码语言:txt复制

vagrant@lvm:~$ sudo vgs -S vgname=lvm_tutorial -o vg_free  VFree   <4.99g

根据输出,我还有一些空间,所以让我们将卷大小增加 2GB。

请记住,逻辑卷仍安装在/mnt.

代码语言:txt复制

vagrant@lvm:~$ mount | grep '/mnt'/dev/mapper/lvm_tutorial-lv1 on /mnt type ext4 (rw,relatime)

使用以下命令调整卷大小:

代码语言:txt复制

sudo lvresize -L +2GB lvm_tutorial/lv1

一般语法是这样的:

代码语言:txt复制

lvresize -L [+|-][Size] /

后面的符号 + 或 –L取决于您是尝试增加音量还是分别减小音量。

卷大小增加后,文件系统也必须调整大小。对于 ext4,要使用的命令是resize2fs.

代码语言:txt复制

sudo resize2fs /dev/lvm_tutorial/lv1

输出:

代码语言:txt复制

vagrant@lvm:~$ sudo resize2fs /dev/lvm_tutorial/lv1resize2fs 1.45.5 (07-Jan-2020)Filesystem at /dev/lvm_tutorial/lv1 is mounted on /mnt; on-line resizing requiredold_desc_blocks = 1, new_desc_blocks = 1The filesystem on /dev/lvm_tutorial/lv1 is now 1835008 (4k) blocks long.

减少逻辑卷是一项稍微复杂的任务,我不会在本文中讨论这个问题。我将把这个卷的大小减少 1GB。

删除逻辑卷

lvremove您可以使用该命令删除逻辑卷。命令语法如下:-

代码语言:txt复制

lvremove /

在虚拟机上运行此命令:-

代码语言:txt复制

sudo lvremove lvm_tutorial/lv1

输出:-

代码语言:txt复制

vagrant@lvm:~$ sudo lvremove lvm_tutorial/lv1Do you really want to remove and DISCARD active logical volume lvm_tutorial/lv1? [y/n]: y  Logical volume "lv1" successfully removed

在逻辑卷、物理卷和卷组上还有许多其他操作可行,但不可能将所有这些都写到一篇文章中。

我/dev/sde在虚拟机中为您多留了一个磁盘,使用它,练习本文中的一些命令,创建一个新的卷组,扩展一个现有的卷组,只是练习。

我希望这篇文章对你有所帮助,如果你想在以后看到更多关于这方面的内容,请在下面的评论部分告诉我。

以上就是Linux 中的逻辑卷 LVM 管理完整初学者指南的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/470414.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 07:18:17
下一篇 2025年11月8日 07:20:21

相关推荐

  • CSS mask属性无法获取图片:为什么我的图片不见了?

    CSS mask属性无法获取图片 在使用CSS mask属性时,可能会遇到无法获取指定照片的情况。这个问题通常表现为: 网络面板中没有请求图片:尽管CSS代码中指定了图片地址,但网络面板中却找不到图片的请求记录。 问题原因: 此问题的可能原因是浏览器的兼容性问题。某些较旧版本的浏览器可能不支持CSS…

    2025年12月24日
    900
  • 为什么设置 `overflow: hidden` 会导致 `inline-block` 元素错位?

    overflow 导致 inline-block 元素错位解析 当多个 inline-block 元素并列排列时,可能会出现错位显示的问题。这通常是由于其中一个元素设置了 overflow 属性引起的。 问题现象 在不设置 overflow 属性时,元素按预期显示在同一水平线上: 不设置 overf…

    2025年12月24日 好文分享
    400
  • 网页使用本地字体:为什么 CSS 代码中明明指定了“荆南麦圆体”,页面却仍然显示“微软雅黑”?

    网页中使用本地字体 本文将解答如何将本地安装字体应用到网页中,避免使用 src 属性直接引入字体文件。 问题: 想要在网页上使用已安装的“荆南麦圆体”字体,但 css 代码中将其置于第一位的“font-family”属性,页面仍显示“微软雅黑”字体。 立即学习“前端免费学习笔记(深入)”; 答案: …

    2025年12月24日
    000
  • 为什么我的特定 DIV 在 Edge 浏览器中无法显示?

    特定 DIV 无法显示:用户代理样式表的困扰 当你在 Edge 浏览器中打开项目中的某个 div 时,却发现它无法正常显示,仔细检查样式后,发现是由用户代理样式表中的 display none 引起的。但你疑问的是,为什么会出现这样的样式表,而且只针对特定的 div? 背后的原因 用户代理样式表是由…

    2025年12月24日
    200
  • inline-block元素错位了,是为什么?

    inline-block元素错位背后的原因 inline-block元素是一种特殊类型的块级元素,它可以与其他元素行内排列。但是,在某些情况下,inline-block元素可能会出现错位显示的问题。 错位的原因 当inline-block元素设置了overflow:hidden属性时,它会影响元素的…

    2025年12月24日
    000
  • 为什么 CSS mask 属性未请求指定图片?

    解决 css mask 属性未请求图片的问题 在使用 css mask 属性时,指定了图片地址,但网络面板显示未请求获取该图片,这可能是由于浏览器兼容性问题造成的。 问题 如下代码所示: 立即学习“前端免费学习笔记(深入)”; icon [data-icon=”cloud”] { –icon-cl…

    2025年12月24日
    200
  • 为什么使用 inline-block 元素时会错位?

    inline-block 元素错位成因剖析 在使用 inline-block 元素时,可能会遇到它们错位显示的问题。如代码 demo 所示,当设置了 overflow 属性时,a 标签就会错位下沉,而未设置时却不会。 问题根源: overflow:hidden 属性影响了 inline-block …

    2025年12月24日
    000
  • 为什么我的 CSS 元素放大效果无法正常生效?

    css 设置元素放大效果的疑问解答 原提问者在尝试给元素添加 10em 字体大小和过渡效果后,未能在进入页面时看到放大效果。探究发现,原提问者将 CSS 代码直接写在页面中,导致放大效果无法触发。 解决办法如下: 将 CSS 样式写在一个单独的文件中,并使用 标签引入该样式文件。这个操作与原提问者观…

    2025年12月24日
    000
  • 为什么我的 em 和 transition 设置后元素没有放大?

    元素设置 em 和 transition 后不放大 一个 youtube 视频中展示了设置 em 和 transition 的元素在页面加载后会放大,但同样的代码在提问者电脑上没有达到预期效果。 可能原因: 问题在于 css 代码的位置。在视频中,css 被放置在单独的文件中并通过 link 标签引…

    2025年12月24日
    100
  • 为什么在父元素为inline或inline-block时,子元素设置width: 100%会出现不同的显示效果?

    width:100%在父元素为inline或inline-block下的显示问题 问题提出 当父元素为inline或inline-block时,内部元素设置width:100%会出现不同的显示效果。以代码为例: 测试内容 这是inline-block span 效果1:父元素为inline-bloc…

    2025年12月24日
    400
  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    300
  • 带有 HTML、CSS 和 JavaScript 工具提示的响应式侧边导航栏

    响应式侧边导航栏不仅有助于改善网站的导航,还可以解决整齐放置链接的问题,从而增强用户体验。通过使用工具提示,可以让用户了解每个链接的功能,包括设计紧凑的情况。 在本教程中,我将解释使用 html、css、javascript 创建带有工具提示的响应式侧栏导航的完整代码。 对于那些一直想要一个干净、简…

    2025年12月24日
    000
  • 布局 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在这里查看视觉效果: 固定导航 – 布局 – codesandbox两列 – 布局 – codesandbox三列 – 布局 – codesandbox圣杯 &#8…

    2025年12月24日
    000
  • 隐藏元素 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看隐藏元素的视觉效果 – codesandbox 隐藏元素 hiding elements hiding elements hiding elements hiding elements hiding element…

    2025年12月24日
    400
  • 居中 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看垂直中心 – codesandbox 和水平中心的视觉效果。 通过 css 居中 垂直居中 centering centering centering centering centering centering立即…

    2025年12月24日 好文分享
    300
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 如何在移动端实现子 div 在父 div 内任意滑动查看?

    如何在移动端中实现让子 div 在父 div 内任意滑动查看 在移动端开发中,有时我们需要让子 div 在父 div 内任意滑动查看。然而,使用滚动条无法实现负值移动,因此需要采用其他方法。 解决方案: 使用绝对布局(absolute)或相对布局(relative):将子 div 设置为绝对或相对定…

    2025年12月24日
    000
  • 移动端嵌套 DIV 中子 DIV 如何水平滑动?

    移动端嵌套 DIV 中子 DIV 滑动 在移动端开发中,遇到这样的问题:当子 DIV 的高度小于父 DIV 时,无法在父 DIV 中水平滚动子 DIV。 无限画布 要实现子 DIV 在父 DIV 中任意滑动,需要创建一个无限画布。使用滚动无法达到负值,因此需要使用其他方法。 相对定位 一种方法是将子…

    2025年12月24日
    000
  • 移动端项目中,如何消除rem字体大小计算带来的CSS扭曲?

    移动端项目中消除rem字体大小计算带来的css扭曲 在移动端项目中,使用rem计算根节点字体大小可以实现自适应布局。但是,此方法可能会导致页面打开时出现css扭曲,这是因为页面内容在根节点字体大小赋值后重新渲染造成的。 解决方案: 要避免这种情况,将计算根节点字体大小的js脚本移动到页面的最前面,即…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信