23.5 Bootstrap 框架6

news2024/9/25 22:36:05

2023-10-09_00013

1. 表单布局

部分表单类名介绍:
* 1. form-label: 表单标签样式类, 用于定义表单的标签样式.
* 2. form-control: 表单控件样式类, 用于定义输入框, 文本域等表单元素的样式.
     表单元素<input>, <textarea>, <select>在使用.form-control类的情况下, 宽度都是设置为100%.
* 3. form-control-sm: 小号尺寸的表单控件样式.
* 4. form-check-label: 表单复选框或单选框标签样式类, 用于添加复选框或单选框的标签样式.
* 5. form-check-input: 表单复选框或单选框输入样式类, 用于定义复选框或单选框的输入样式.	
* 6. form-check: 表单复选框或单选框容器样式类, 用于将复选框或单选框包装在一个容器中.
在使用Bootstrap 5布局表单时, 可以选择堆叠表单或内联表单来满足不同的布局需求.
* 1. 堆叠表单(全屏宽度, 垂直方向).
     堆叠表单是指表单元素以垂直方向排列, 并且占据整个父容器的宽度.
     这样的布局适用于提供更多垂直空间的情况.

* 2. 内联表单(水平方向).
     内联表单是指表单元素以水平方向排列, 适合在更有限的空间中显示表单, 表单元素会在同一行上并排显示.

1.1 堆叠表单

通过一些组类名的组合, 实现堆叠形式的表单布局.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>堆叠表单</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">
        <div class="mb-3 mt-3">
            <label for="username" class="form-label">用户名称:</label>
            <!-- form-control 让输入框独占一行 -->
            <input type="text" class="form-control" id="username" placeholder="输入用户名称" name="username">
        </div>
        <div class="mb-3">
            <label for="password" class="form-label">用户密码:</label>
            <input type="password" class="form-control" id="password" placeholder="输入用户密码" name="password">
        </div>
        <div class="form-check mb-3">
            <label class="form-check-label">
                <input class="form-check-input" type="checkbox" name="remember"> 我已阅读xx条款!
            </label>
        </div>
        <button type="submit" class="btn btn-primary">登录</button>
    </form>
</div>

</body>
</html>

image-20231008002202389

1.2 内联表单

使用.row和.col类创建内联表单, 让输入框并排显示.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>内联表单</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>
    <style>
        input:hover {
            border-color: #80bdff; /* 自定义边框颜色 */
            box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
        }
    </style>
</head>
<body>
<div class="container mt-3">
    <form action="">
        <div class="row">
            <div class="col">
                <label for="username">用户名称:</label>
                <input type="text" class="form-control-sm" placeholder="输入用户名称" name="username" id="username">
            </div>
            <div class="col mb-3">
                <label for="password">输入用户密码:</label>
                <input type="password" class="form-control-sm" placeholder="输入用户密码" name="password" id="password">
            </div>
        </div>

        <div class="row">
            <div class="col">
                <div class="form-check mb-4">
                    <label class="form-check-label">
                        <input class="form-check-input" type="checkbox" name="remember"> 我已阅读xx条款!
                    </label>
                </div>
            </div>

            <div class="col">
                <button type="submit" class="btn btn-sm btn-primary">登录</button>
            </div>
        </div>
    </form>
</div>
</body>
</html>

image-20231008010743164

2. 文本框样式

在Bootstrap 5 , 可以使用.form-control类渲染文本框textareas标签, 100%的宽度.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>文本框样式</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">
        <div class="mb-3 mt-3">
            <label for="comment">请输入评论:</label>
           <!-- 5行 -->
            <textarea class="form-control" rows="5" id="comment" name="text"></textarea>
        </div>
        <button type="submit" class="btn btn-primary">提交</button>
    </form>
</div>
</body>
</html>
宽度固定, 无法拖动!

image-20231008004155943

3. 输入框大小

在Bootstrap 5 , 可以通过.form-control-*类设置输入框的大小, 相关类名及其介绍:
* 1. .form-control: 默认, 正常大小输入框, 高度100%.
* 2. .form-control-lg: 用于将输入框设置为大号, 它会增加输入框的高度和宽度, 使其显得更大.
* 3. .form-control-sm: 则用于将输入框设置为小号, 它会减小输入框的高度和宽度, 使其显得更小.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>输入框大小</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form>
        <!-- 组合使用, 宽度100% -->
        <input type="text" class="form-control form-control-lg" placeholder="大号输入框">
        <input type="text" class="form-control mt-3" placeholder="正常大小输入框">
        <input type="text" class="form-control form-control-sm mt-3" placeholder="小号输入框">
    </form>
</div>
</body>
</html>

image-20231008010919576

4. 表单状态

可以使用disabled属性和readonly属性来设置输入框的禁用状态与只读状态. 
这两个属性可以直接添加到<input>元素上.

属性介绍:
* 1. disabled属性: 禁用输入框, 使其无法接收用户的输入, 并且在外观上呈现禁用状态.

* 2. readonly属性: 将输入框设置为只读, 用户不能直接编辑值, 但仍然可以复制文本或选中文本.
     value设置的值可以复制, placeholder设置的提示信息无法复制.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>禁用/只读表单</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form>
        <input type="text" class="form-control" placeholder="正常输入框">
        <input type="text" class="form-control mt-3" placeholder="禁用输入框" disabled>
        <input type="text" class="form-control mt-3" placeholder="只读输入框" readonly>
    </form>
</div>

</body>
</html>

image-20231008011328793

5. 纯文本输入

在Bootstrap 5 , .form-control-plaintext类, 用于将输入框以纯文本的形式呈现, 使其具有只读的效果, 并删除输入框的边框.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>纯文本输入</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">

    <form>
        <input type="text" class="form-control-plaintext" placeholder="无边框的输入框">
        <input type="text" class="form-control" placeholder="正常输入框">
    </form>
</div>
</body>
</html>

image-20231008011804864

6. 取色器

在Bootstrap 5 , .form-control-color类, 用于将输入框转换为颜色选择器.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>取色器</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form>
        <label for="color" class="from-label mb-1">颜色:</label>
        <input type="color" class="form-control form-control-color" value="#CCCCCC" id="color">
    </form>
</div>
</body>
</html>

image-20231008012236210

7. 下拉选择框

7.1 下拉选择框样式

在Bootstrap 5 , .form-select类用于将<select>元素转换为样式化的选择框.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>下拉选择框</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">
        <label for="sel1" class="form-label">单选下拉菜单:</label>
        <select class="form-select" id="sel1" name="sellist1">
            <option>1</option>
            <option>2</option>
            <option>3</option>
            <option>4</option>
        </select>
        <br>

        <!-- 按下ctrl进行多选-->
        <label for="sel2" class="form-label">多选下拉菜单:</label>
        <select multiple class="form-select" id="sel2" name="sellist2">
            <option>1</option>
            <option>2</option>
            <option>3</option>
            <option>4</option>
            <option>5</option>
        </select>
        <button type="submit" class="btn btn-primary mt-3">提交</button>
    </form>
</div>
</body>
</html>

image-20231008013524990

7.2 下拉选择框大小

在Bootstrap 5 , 可以使用.form-select-lg或.form-select-sm类来修改下拉菜单的大小.
.form-select-lg: 用于创建大尺寸的下拉菜单.
.form-select-sm: 用于创建小尺寸的下拉菜单.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>下拉选择框大小</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">
        <label for="sel1" class="form-label">大号下拉选择框:</label>
        <select class="form-select form-select-lg" id="sel1" name="sellist1">
            <option>1</option>
            <option>2</option>
        </select>
        <br>

        <label for="sel2" class="form-label">正常下拉选择框: </label>
        <select class="form-select mb-3" id="sel2" name="sellist2">
            <option>1</option>
            <option>2</option>
        </select>

        <label for="sel3" class="form-label">小号下拉选择框:</label>
        <select class="form-select form-select-sm" id="sel3" name="sellist3">
            <option>1</option>
            <option>2</option>
        </select>
        <button type="submit" class="btn btn-primary mt-3">提交</button>
    </form>
</div>
</body>
</html>

image-20231008013833294

7.3 禁用

可以使用disabled属性禁用下拉选择框.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>禁用下拉选择框</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">

    <form action="">
        <label for="sel" class="form-label">下拉选择框:</label>
        <select class="form-select" id="sel" name="sellist" disabled>
            <option>1</option>
            <option>2</option>
        </select>
        <button type="submit" class="btn btn-primary mt-3">提交</button>
    </form>
</div>
</body>
</html>

image-20231008014321802

7.4 数据列表

<datalist> 标签可以为 <input> 元素设置拉菜单选项列表.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>数据列表1</title>
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
</head>
<body>
<div class="container mt-3">
    <form action="">
        <!-- 需要清除选项后才能重新选择-->
        <label for="site" class="form-label">1 + 1 = ?</label>
        <!--        设置不记录历史数据autocomplete="off", 否则选择会多一些历史数据!!!-->
        <input class="form-control" list="sites" name="site" id="site"
               autocomplete="off">
        <datalist id="sites">
            <option value="1">
            <option value="2">
            <option value="3">
        </datalist>
    </form>
</div>
</body>
</html>

image-20231008020912298

设置一个自动清除选择的按钮...
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>数据列表2</title>
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
</head>
<body>
<div class="container mt-3">
    <form action="" id="myForm">
        <label for="site" class="form-label">选择搜索工具:</label>
        <div class="input-group">
            <input class="form-control" list="sites" name="site" id="site">
            <button type="button" class="btn btn-outline-secondary" id="clearBtn">清除</button>
        </div>
        <datalist id="sites">
            <option value="谷歌">
            <option value="百度">
            <option value="chat-gpt">
        </datalist>
        <label for="issue" class="form-label">搜索的问题:</label>
        <input type="text" id="issue" class="form-control">


        <button type="submit" class="btn btn-primary mt-3">提交</button>
    </form>
</div>


<script>
    document.getElementById("clearBtn").addEventListener("click", function () {
        document.getElementById("site").value = "";
    });

    document.getElementById("myForm").addEventListener("reset", function () {
        document.getElementById("site").value = "";
    });
</script>
</body>
</html>

image-20231008020957993

8. 选项框

在Bootstrap 5, 用于构建表单单选框样式的相关类名及其介绍:
* 1. .form-check类: 复选框和单选框的父容器元素, 确保标签和复选框有适当边距
* 2. .form-check-label: 用于自定义表单选项文本标签(label)的样式, 可以通过该类名来设置文本的颜色, 字体大小, 对齐方式等样式属性.
* 3. .form-check-input: 用于自定义表单选项输入控件(checkbox或radio)的样式, 
      可以通过该类名来设置控件的外观, 选中状态的颜色, 大小等样式属性.

8.1 单选框

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>单选框</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">
        <div class="form-check">
            <!--      checked属性默认选中      -->
            <input type="radio" class="form-check-input" id="radio1" name="optradio" value="option1" checked>
            <label class="form-check-label" for="radio1">选项 1</label>
        </div>
        <div class="form-check">
            <input type="radio" class="form-check-input" id="radio2" name="optradio" value="option2">
            <label class="form-check-label" for="radio2">选项 2</label>
        </div>
        <div class="form-check">
            <!--      disabled属性禁用      -->
            <input type="radio" class="form-check-input" id="radio" disabled>
            <label class="form-check-label" for="radio">选项 3</label>
        </div>
        <button type="submit" class="btn btn-primary mt-3">提交</button>
    </form>
</div>
</body>
</html>

image-20231008183532294

8.2 复选框

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>复选框</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>
</head>
<body>
<div class="container mt-3">

    <form action="">
        <div class="form-check">
            <input type="checkbox" class="form-check-input" id="check1" name="option1" value="something" checked>
            <label class="form-check-label" for="check1">选项 1</label>
        </div>
        <div class="form-check">
            <input type="checkbox" class="form-check-input" id="check2" name="option2" value="something">
            <label class="form-check-label" for="check2">选项 2</label>
        </div>
        <div class="form-check">
            <input type="checkbox" class="form-check-input" id="check3" disabled>
            <label class="form-check-label" for="check3">选项 3</label>
        </div>
        <button type="submit" class="btn btn-primary mt-3">提交</button>
    </form>
</div>
</body>
</html>

image-20231008190226531

8.3 切换开关

在Bootstrap 5, 可以在.form-check容器内使用.form-switch类把复选框变成一个可切换的开关.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>复选框切换开关</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">
        <div class="form-check form-switch">
            <input type="checkbox" class="form-check-input" id="checkbox1" name="learning" value="yes">
            <label class="form-check-label" for="checkbox1">开启学习模式</label>
        </div>
        <button type="submit" class="btn btn-primary mt-3">提交</button>
    </form>
</div>

</body>
</html>

image-20231008190458389

9. 选择区间

9.1 选择区间样式

设置一个选择区间可以在input元素中添加type="range"并使用.form-range类名.

在Bootstrap 5, .form-range类用于自定义滑块(range input)的样式类.
提供一致的样式, 包括滑块的背景, 滑块轨道, 滑块控制点的颜色, 尺寸和边框样式.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>选择区间</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">
        <label for="defaultRange" class="form-label">默认选择区间</label>
        <input type="range" id="defaultRange" name="points"><br>

        <label for="customRange" class="form-label">自定义选择区间</label>
        <input type="range" class="form-range" id="customRange" name="points">

        <button type="submit" class="btn btn-primary mt-3">Submit</button>
    </form>
</div>
</body>
</html>

image-20231008234921967

9.2 区间步长

默认情况下, 步长为 1; 可以通过step属性来设置区间步长, 滑动滑块时跨越的刻度.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>区间步长</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">
        <label for="customRange" class="form-label">自定义步长</label>
        <input type="range" class="form-range" id="customRange" step="10">
        <button type="submit" class="btn btn-primary mt-3">Submit</button>
    </form>
</div>
</body>
</html>

GIF 2023-10-9 0-02-53

9.3 取值范围

可以在<input>元素中使用min和max属性用于指定滑块的最小值和最大值, 以此规定取值范围.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>取值范围</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">

        <label for="customRange" class="form-label">取值范围</label>
        <input type="range" class="form-range" id="customRange" min="0" max="4">
        <button type="submit" class="btn btn-primary mt-3">Submit</button>
    </form>
</div>
</body>
</html>

image-20231009000940440

10. 输入框组

10.1 输入框组样式

在Bootstrap 5, 用于设置输入框组样式的相关类名及其介绍:
* 1. .input-group: 用于向表单输入框添加更多的样式, 如图标, 文本或按钮.
* 2. .input-group-text: 用于设置.input-group内部元素的的文本样式.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>输入框组</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form>
        <div class="input-group mb-3">
            <!--	不要设置label, 否则样式存在瑕疵		-->
            <span class="input-group-text">@</span>
            <input type="text" id="username" class="form-control" placeholder="用户名称">
        </div>

        <div class="input-group">
            <input type="text" class="form-control" placeholder="输入邮箱">
            <span class="input-group-text">@qq.com</span>
        </div>
    </form>
</div>
</body>
</html>

image-20231009002027263

10.2 输入框大小

在Bootstrap 5, 用于设置输入框组中输入框大小样式的相关类名及其介绍:
* 1. .input-group-sm: 设置小号的输入框.
* 2. .input-group-lg: 设置大号的输入框.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>输入框大小</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">

    <div class="input-group input-group-sm mb-3">
        <span class="input-group-text">小号输入框</span>
        <input type="text" class="form-control">
    </div>
    <div class="input-group mb-3">
        <span class="input-group-text">默认输入框</span>
        <input type="text" class="form-control">
    </div>
    <div class="input-group input-group-lg mb-3">
        <span class="input-group-text">大号输入框</span>
        <input type="text" class="form-control">
    </div>
</div>
</body>
</html>

image-20231009002619926

10.3 多个输入框

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>多个输入框</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <div class="input-group">
        <span class="input-group-text">个人信息</span>
        <input type="text" class="form-control" placeholder="姓氏">
        <input type="text" class="form-control" placeholder="名字">
    </div>
</div>
</body>
</html>

image-20231009002923135

10.4 多个文本

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>多个文本</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">

    <div class="input-group">
        <span class="input-group-text">1</span>
        <span class="input-group-text">+</span>
        <span class="input-group-text">1</span>
        <span class="input-group-text">=</span>
        <input type="text" class="form-control">
    </div>
</div>
</body>
</html>

image-20231009003212628

10.5 选项框

文本信息可以使用复选框与单选框替代.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>选择框</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <!-- 单选框选中后无法取消  -->
    <div class="input-group mb-3">
        <div class="input-group-text">
            <input type="radio">
        </div>
        <input type="text" class="form-control" placeholder="开启数据">
    </div>

    <div class="input-group mb-3">
        <div class="input-group-text">
            <input type="checkbox">
        </div>
        <input type="text" class="form-control" placeholder="开启WIFI">
    </div>
</div>
</body>
</html>

image-20231009003805479

10.6 按钮组

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>按钮组</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <div class="input-group mb-3 mt-3">
        <button class="btn btn-outline-primary" type="button">基本按钮</button>
        <input type="text" class="form-control" placeholder="一些文本">
    </div>

    <div class="input-group mb-3">
        <input type="text" class="form-control" placeholder="搜索">
        <button class="btn btn-success" type="submit">搜索</button>
    </div>

    <div class="input-group mb-3">
        <input type="text" class="form-control" placeholder="一些信息">
        <button class="btn btn-primary" type="button">确定</button>
        <button class="btn btn-danger" type="button">取消</button>
    </div>
</div>
</body>
</html>

image-20231009004351077

10.7 下拉菜单

输入框中添加下拉菜单不需要使用.dropdown类.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>下拉菜单</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <div class="input-group mt-3 mb-3">
        <input type="text" class="form-control" placeholder="搜索">

        <button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown">
            Go
        </button>
        <ul class="dropdown-menu">
            <li><a class="dropdown-item" href="#">百度</a></li>
            <li><a class="dropdown-item" href="#">谷歌</a></li>
            <li><a class="dropdown-item" href="#">gpt-3.5</a></li>
        </ul>

    </div>
</div>

</body>
</html>

image-20231009004841443

10.8 标签

输入框组通过在输入框组外围的label来设置标签, 标签的for属性与输入框组的id对应, 设置之后点击标签后可以聚焦输入框.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>标签</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form>
        <label for="demo">邮箱:</label>
        <div class="input-group mb-3">
            <input type="text" class="form-control" placeholder="邮箱" id="demo" name="email">
            <span class="input-group-text">@qq.com</span>
        </div>
    </form>
</div>

</body>
</html>

image-20231009005238758

11. 表单浮动

11.1 表单浮动样式

在Bootstrap 5,  form-floating类用于创建浮动标签(floating label)的表单元素样式的容器.
它会使容器内的标签(label)会变成一个浮动标签, 会在用户输入内容时向上浮动, 以给予用户更多的可见空间.

默认情况下, 标签内容一般显示在input输入框的上方.
使用浮动标签, 可以在input输入框内插入提示信息的标签, 在单击input输入框时, 将提示信息浮动光标的上方.

注意事项:
* 1. <label>元素必须在<input>元素之后.
* 2. 每个<input>元素都需要placeholder属性(虽然它不起作用, 但不设置则不会有点击浮动效果, 而是直接上浮).
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>表单浮动</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">
        <div class="form-floating mb-3 mt-3">
            <!--  placeholder 属性失效 -->
            <input type="text" class="form-control" id="email" placeholder="Enter email" name="email">
            <label for="email" class="text-secondary">邮件</label>
        </div>
        <div class="form-floating mt-3 mb-3">
            <input type="text" class="form-control" id="password" placeholder="Enter password" name="Password">
            <label for="password" class="text-secondary">密码</label>
        </div>
        <button type="submit" class="btn btn-primary">提交</button>
    </form>
</div>
</body>
</html>

GIF 2023-10-9 1-24-10

11.2 文本框

文本框textarea可以有浮动效果.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>文本框</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">

    <form action="">
        <div class="form-floating mb-3 mt-3">
            <textarea class="form-control" id="comment" name="text" placeholder="Comment"></textarea>
            <label for="comment">评论</label>
        </div>
        <button type="submit" class="btn btn-primary">提交</button>
    </form>
</div>
</body>
</html>

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

11.3 下拉选择框

在选择菜单上使用浮动标签, 它将始终显示在选择菜单的左上角, 不会有点击浮动效果.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>下拉选择框</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container mt-3">
    <form action="">
        <div class="form-floating mb-3 mt-3">
            <select class="form-select" id="sel1" name="sellist">
                <option>选项1</option>
                <option>选项2</option>
                <option>选项3</option>
                <option>选项4</option>
            </select>
            <label for="sel1" class="form-label">单选题:</label>
        </div>
        <button type="submit" class="btn btn-primary">提交</button>
    </form>
</div>
</body>
</html>

GIF 2023-10-9 1-35-04

12. 表单验证

12.1 表单验证样式

在Bootstrap 5, 用于表单验证的相关类名及其介绍:
* 1. .was-validated: 用于已经完成验证的表单.
      当表单中至少一个表单控件验证不通过时, 该类会自动应用于包含整个表单的父元素, 从而触发验证样式和反馈的显示.
      这样可以向用户显示哪些控件未通过验证, 并让用户进行必要的更正.
 
* 2. .needs-validation: 用于启用表单验证.
      想要启用表单验证功能时, 将这个类应用于包含整个表单的父元素.
      这样, 当用户提交表单时, Bootstrap表单验证功能就会生效, 
      并根据指定的验证规则自动判断表单控件是否合法, 并显示相应的验证样式和反馈.

* 3. .valid-feedback: 用于在通过验证的表单控件后显示反馈消息的类.
     可以将它应用于需要显示成功消息的元素, 例如输入字段或选择框.
     
* 4. .invalid-feedback: 用于在未通过验证的表单控件后显示反馈消息的类.
     可以将它应用于需要显示错误消息的元素, 例如输入字段或选择框.

使用这些类可以提供可视化的表单验证反馈, 使用户能够轻松地了解哪些表单控件通过验证, 哪些未通过验证.
.was-validated与.needs-validation的区别:
* .was-validated类表示表单已经完成验证, 并且会触发验证样式和反馈的显示.
*  .needs-validation类用于启用表单验证, 在用户提交表单时会触发验证功能.

通常, 不需要同时使用这两个类.
如果你想要启用表单验证功能, 并让用户在提交表单时显示验证结果, 只需将.needs-validation类应用于表单元素的父元素即可.
一旦用户提交表单, 如果有任何验证失败, .was-validated类会自动添加到父元素中, 触发验证样式和反馈的显示.

12.2 表单验证

使用.was-validated类显示表单在提交之前需要填写的内容.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>表单验证</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container">
    <form action="" class="was-validated">
        <div class="form-group">
            <label for="uname">Username:</label>
            <input type="text" class="form-control" id="uname" placeholder="Enter username" name="uname" required>
            <div class="valid-feedback">验证成功!</div>
            <div class="invalid-feedback">请输入用户名!</div>
        </div>
        <div class="form-group">
            <label for="pwd">Password:</label>
            <input type="password" class="form-control" id="pwd" placeholder="Enter password" name="pswd" required>
            <div class="valid-feedback">验证成功!</div>
            <div class="invalid-feedback">请输入密码!</div>
        </div>
        <div class="form-group form-check">
            <label class="form-check-label" for="remember">同意协议</label>
            <input class="form-check-input" type="checkbox" id="remember" name="remember" required>
            <div class="valid-feedback">验证成功!</div>
            <div class="invalid-feedback">同意协议才能提交.</div>

        </div>
        <button type="submit" class="btn btn-primary">提交</button>
    </form>
</div>
</body>
</html>

GIF 2023-10-9 1-44-25

12.3 验证缺少内容

使用.needs-validation类, 它将在表单提交之后验证缺少的内容.
这里需要添加一些js代码才能使代码正常工作.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>验证缺少内容</title>
    <link href="bootstrap-5.3.2-dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="bootstrap-5.3.2-dist/js/bootstrap.bundle.min.js"></script>

</head>
<body>
<div class="container">
    <h2>表单验证</h2>
    <form action="" class="needs-validation" novalidate>
        <div class="form-group">
            <label for="uname">Username:</label>
            <input type="text" class="form-control" id="uname" placeholder="Enter username" name="uname" required>
            <div class="valid-feedback">验证成功!</div>
            <div class="invalid-feedback">请输入用户名!</div>
        </div>
        <div class="form-group">
            <label for="pwd">Password:</label>
            <input type="password" class="form-control" id="pwd" placeholder="Enter password" name="pswd" required>
            <div class="valid-feedback">验证成功!</div>
            <div class="invalid-feedback">请输入密码!</div>
        </div>
        <div class="form-group form-check">
            <label class="form-check-label" for="remember">同意协议</label>
            <input class="form-check-input" type="checkbox" id="remember" name="remember" required>
            <div class="valid-feedback">验证成功!</div>
            <div class="invalid-feedback">同意协议才能提交.</div>
        </div>
        <button type="submit" class="btn btn-primary">提交</button>
    </form>
</div>

<script>
    // 如果验证不通过禁止提交表单
    (function () {
        'use strict';
        window.addEventListener('load', function () {
            // 获取表单验证样式
            var forms = document.getElementsByClassName('needs-validation');
            // 循环并禁止提交
            var validation = Array.prototype.filter.call(forms, function (form) {
                form.addEventListener('submit', function (event) {
                    if (form.checkValidity() === false) {
                        event.preventDefault();
                        event.stopPropagation();
                    }
                    form.classList.add('was-validated');
                }, false);
            });
        }, false);
    })();
</script>
</body>
</html>

GIF 2023-10-9 2-07-00

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1074160.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

取消激光雷达/不升级Orin,小鹏P5改款背后的行业「痛点」

9月25日&#xff0c;小鹏汽车正式发布了旗下改款车型—2024款小鹏P5&#xff08;15.69-17.49万元&#xff09;。车型精简、降本增效&#xff08;减配&#xff09;成为新亮点。 在配置变化方面&#xff0c;智驾成为牺牲品。其中&#xff0c;高配Pro车型继续保留英伟达Xavier&…

Cpolar内网穿透工具在windows和Linux上具体使用

Cpolar内网穿透工具在windows和Linux上具体使用 一、Linux上部署的项目通过内网穿透实现外网访问项目二、Windows上部署的项目通过内网穿透实现外网访问项目 一、Linux上部署的项目通过内网穿透实现外网访问项目 一个免费的内网穿透方式&#xff0c;简单方便。 网址&#xff1a…

MyBatisPlus(十六)逻辑删除

说明 实际生产中的数据&#xff0c;一般不采用物理删除&#xff0c;而采用逻辑删除&#xff0c;也就是将一条记录的状态改为已删除。 逻辑删除&#xff0c;本质上是更新操作。 MyBatis Plus 框架&#xff0c;提供了逻辑删除功能。在配置了逻辑删除后&#xff0c;增删改查和统…

设计模式 - 状态模式

目录 一. 前言 二. 实现 一. 前言 状态模式&#xff08;State Pattern&#xff09;&#xff1a;它主要用来解决对象在多种状态转换时&#xff0c;需要对外输出不同的行为的问题。状态和行为是一一对应的&#xff0c;状态之间可以相互转换。当一个对象的内在状态改变时&#x…

超越React,JS代码体积减少90%!它为何是2023年最好的Web框架?

说到Web框架&#xff0c;大家最先想到的可能是 Vue、React&#xff0c;或者是Next.js。但不得不提&#xff0c;有个后起之秀“来势汹汹”&#xff0c;1.0版本发布至今仅一年&#xff0c;就出尽风头。它就是Astro。 Astro 是什么&#xff1f;一个现代化的静态站点生成器和前端框…

nginx反向代理实例

一、代理模式 如果域名没有备案&#xff0c;访问国内的云主机时&#xff0c;会被防火墙拦截&#xff0c;但是如果先解析到香港主机&#xff0c;然后反向代理到国内的云主机&#xff0c;就可以绕过备案访问了。 香港服务器可以在亿速云购买&#xff0c;域名可以在阿里云购买&a…

3.3.OpenCV技能树--二值图像处理--图像形态学操作

文章目录 1.图像形态学运算简介2.图像开运算处理2.1.图像开运算处理简介2.2.图像开运算处理代码2.3.图像开运算处理效果 3.图像闭运算处理3.1.图像闭运算处理简介3.2.图像闭运算处理代码3.3.图像闭运算处理效果 4.图像形态学梯度处理4.1.图像形态学梯度处理简介4.2.图像形态学梯…

网康 NS-ASG安全网关存在远程命令执行漏洞 复现

文章目录 网康 NS-ASG安全网关存在远程命令执行漏洞 复现0x01 前言0x02 漏洞描述0x03 影响版本0x04 漏洞环境0x05 漏洞复现1.访问漏洞环境2.构造POC3.复现 0x06 修复建议 网康 NS-ASG安全网关存在远程命令执行漏洞 复现 0x01 前言 免责声明&#xff1a;请勿利用文章内的相关技…

基于SpringBooy的安康旅游网站的设计与实现

目录 前言 一、技术栈 二、系统功能介绍 登录模块的实现 景点信息管理界面 酒店信息管理界面 特产管理界面 游客管理界面 景点购票订单管理界面 系统主界面 游客注册界面 景点信息详情界面 酒店详情界面 特产详情界面 三、核心代码 1、登录模块 2、文件上传模块…

Nginx + PHP 异常排查,open_basedir 异常处理

新上一个网站&#xff0c;通过域名访问失败&#xff0c;排查方法如下&#xff1a; 开启异常日志 开启域名下&#xff0c;nginx的异常日志&#xff0c;并查看日志 tail -f /var/log/nginx/nginx.localhost.error.log开启php的异常日志&#xff0c;该配置位于php.ini文件下 …

Java 21:虚拟线程介绍

Java 21 版本更新中最重要的功能之一就是虚拟线程 (JEP 444)。这些轻量级线程减少了编写、维护和观察高吞吐量并发应用程序所需的工作量。 正如我的许多其他文章一样&#xff0c;在推出新功能之前&#xff0c;让我们先看看 Java 21 版本更新前的现状&#xff0c;以便更好地了解…

Denoising Score Matching (DSM) 去噪得分匹配模型变分推理(VAE)退火郎之万动力学

Denoising Score Matching——DSM 有没有谁通俗的讲一下Denoising score matching? Denoising Score Matching (DSM) 论文 << A Connection Between Score Matching and Denoising Autoencoders>> 作者是将denoising autoencoder和score mathching 联系在了一起…

图像处理与计算机视觉--第七章-神经网络-单层感知器

文章目录 1.单层感知器原理介绍2.单层感知器算法流程3.单层感知器算法实现4.单层感知器效果展示5.参考文章与致谢 1.单层感知器原理介绍 1.单层感知器是感知器中最简单的一种&#xff0c;有单个神经元组成的单层感知器只能用于解决线性可分的二分性问题2.在空间中如果输入的数据…

《spring security in action》读书笔记

1. why spring security 是强大的高度可定制的 身份验证 和 访问控制 应用级框架。 常见的漏洞包含&#xff1a; 身份验证失效&#xff0c;会话固定&#xff0c;跨站脚本xss请求伪造&#xff0c;CSRF注入敏感数据泄漏缺乏方法访问控制。 身份验证失效&#xff1a; 不能仅仅验…

基于正点原子alpha开发板的第三篇系统移植

系统移植的三大步骤如下&#xff1a; 系统uboot移植系统linux移植系统rootfs制作 一言难尽&#xff0c;踩了不少坑&#xff0c;当时只是想学习驱动开发&#xff0c;发现必须要将第三篇系统移植弄好才可以学习后面驱动&#xff0c;现将移植好的文件分享出来&#xff1a; 仓库&…

一篇讲清楚Java for循环详解

for 语句是应用最广泛、功能最强的一种循环语句。大部分情况下&#xff0c;for 循环可以代替 while 循环、do while 循环。 for 语句是一种在程序执行前就要先判断条件表达式是否为真的循环语句。假如条件表达式的结果为假&#xff0c;那么它的循环语句根本不会执行。for 语句通…

七个有用的 GIT 命令

在这篇文章中&#xff0c;我将与你分享7个 GIT 命令。 它们是有用的简短命令&#xff0c;但有时我们会错过它们。 01、查看之前的分支 我们将从一个非常短的 git 命令开始这个列表。 有时&#xff0c;我们在分支机构工作。 对于某些季节&#xff0c;我们需要切换到另一个分支…

图片批量处理:将长图切割成短图,轻松高效!

在日常生活中&#xff0c;我们经常需要处理大量的图片&#xff0c;包括上传和下载的图片。有时候&#xff0c;我们可能需要将这些长图切割成几个短图&#xff0c;以便更好地管理和使用。但是&#xff0c;如何快速高效地完成这个任务呢&#xff1f;今天&#xff0c;我们将向你介…

ViewPager、RecycleView实现轮播图

1.ViewPager实现轮播图形效果。 1&#xff09;layout中&#xff0c;PageIndicatorView轮播的View <RelativeLayoutandroid:layout_width"match_parent"android:layout_height"200dp"android:orientation"vertical"><androidx.viewpager…

nio 文件传输

transferto方法一次只能传输2个g的数据 文件大于2个g时