Bootstrap 模态框

Bootstrap 模态框(Modal)插件

模态框(Modal)是覆盖在父窗体上的子窗体。通常,目的是显示来自一个单独的源的内容,可以在不离开父窗体的情况下有一些互动。子窗体可提供信息、交互等。

用法

1.通过 data 属性:在控制器元素(比如按钮或者链接)上设置属性 data-toggle=“modal”,同时设置 data-target="#identifier" 或 href="#identifier" 来指定要切换的特定的模态框(带有 id=“identifier”)。
2.通过 JavaScript:使用这种技术,您可以通过简单的一行 JavaScript 来调用带有 id=“identifier” 的模态框:$('#identifier').modal(options)

实例
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>模态框</title>
	<link rel="stylesheet" href="./bootstrap-3.3.7/css/bootstrap.css">
	<script src="./js/jquery-3.4.1.min.js"></script>
	<script src="./bootstrap-3.3.7/js/bootstrap.min.js"></script>
	<script>
		$(function(){
			var option = '';
			//代表当前操作对象的id
			var currentId = '';
			//新增按钮
			$('#to-add').click(function(){
				option = '新增';
				//情况数据
				$('.modal [type=text],.modal [type=password]').val(null);
				$('.modal [type=radio]:checked').prop('checked',false);
				//更改标题
				$('.modal-title').text(option+'信息');
				$('#myModal').modal('show');
			});

			//修改
			$('#to-update').click(function(){
				option = '修改';
				//可以通过修改按钮获取当前对象的id,拿到id之后向后台要数据
				//假设这是从后台拿到的数据
				var obj = {
					username:'Pual',
					password:1234567,
					gender:'男',
					id:1001,
				};
				currentId = obj.id;
				$('.modal [type=text]').val(obj.username);
				$('.modal [type=password]').val(obj.password);
				//选择value值为obj.gender并把它设置成选中转态
				$('.modal [type=radio][value='+obj.gender+']').prop('checked',true);
				$('.modal-title').text(option+'信息');
				$('#myModal').modal('show');
			});

			//保存按钮
			$('#to-save').click(function(){
				//获取数据封装成对象
				var username = $('.modal [type=text]').val();
				var password = $('.modal [type=password]').val();
				var gender = $('.modal [name=gender]:checked').val();
				if (username&&password&&gender) {
					var obj = {
						username:username,
						password:password,
						gender:gender,
					};
					if (option === '修改') {
						obj.id = currentId;
					}
					console.log('传递给后台的数据:',obj);
					//提交成功的回调函数里更新数据,关闭模态框
					$('#myModal').modal('hide');
				}else {
					alert('请输入完整信息');
				}
			});
		});
	</script>
</head>
<body>
	<div class="container">
		<div class="modal fade" id="myModal">
			<div class="modal-dialog">
				<div class="modal-content">
					<div class="modal-header">
						<button class="btn btn-default close" data-dismiss="modal">&times;</button>
						<span class="modal-title"></span>
					</div>
					<div class="modal-body">
						<form class="form-horizontal">
							<div class="form-group">
								<label for="uname" class="col-md-2 control-label">
									用户名:
								</label>
								<div class="col-md-10">
									<input type="text" class="form-control" id="uname" placeholder="Username">
								</div>
							</div>
							<div class="form-group">
								<label for="upwd" class="col-md-2 control-label">
									密码:
								</label>
								<div class="col-md-10">
									<input type="password" class="form-control" id="upwd" placeholder="Password">
								</div>
							</div>
							<div class="form-group">
								<label for="male" class="col-md-2 control-label">
									性别:
								</label>
								<div class="col-md-10">
									<div class="radio-inline">
										<label for="male">
											<input type="radio" name="gender" value="" id="male"></label>
									</div>
									<div class="radio-inline">
										<label for="female">
											<input type="radio" name="gender" value="" id="female"></label>
									</div>
								</div>
							</div>
						</form>
					</div>
					<div class="modal-footer">
						<button class="btn btn-default" data-dismiss="modal">
							取消
						</button>
						<button class="btn btn-primary" id="to-save">
							保存
						</button>
					</div>
				</div>
			</div>
		</div>
		<br>
		<br>
		<div class="btn-group btn-group-justified">
			<div class="btn-group">
				<button id="to-add" class="btn btn-primary">新增</button>
			</div>
			<div class="btn-group">
				<button id="to-update" class="btn btn-danger">修改</button>
			</div>
		</div>
	</div>
</body>
</html>
代码讲解:

1.使用模态窗口,您需要有某种触发器。您可以使用按钮或链接。这里我们使用的是按钮。
2.如果您仔细查看上面的代码,您会发现在 <button> 标签中,data-target="#myModal" 是您想要在页面上加载的模态框的目标。您可以在页面上创建多个模态框,然后为每个模态框创建不同的触发器。现在,很明显,您不能在同一时间加载多个模块,但您可以在页面上创建多个在不同时间进行加载。
3.在模态框中需要注意两点:
第一是 .modal,用来把 <div> 的内容识别为模态框。
第二是 .fade class 当模态框被切换时,它会引起内容淡入淡出。
4.aria-labelledby="myModalLabel",该属性引用模态框的标题。
5.属性 aria-hidden="true" 用于保持模态窗口不可见,直到触发器被触发为止(比如点击在相关的按钮上)。
6.<div class="modal-header">modal-header 是为模态窗口的头部定义样式的类。
7.class="close",close 是一个 CSS 类,用于为模态窗口的关闭按钮设置样式。
8.data-dismiss="modal",是一个自定义的 HTML5 data 属性。在这里它被用于关闭模态窗口。
9.class="modal-body",是 Bootstrap CSS 的一个 CSS类,用于为模态窗口的主体设置样式。
10.class="modal-footer",是 Bootstrap CSS 的一个 CSS类,用于为模态窗口的底部设置样式。
11.data-toggle="modal",HTML5 自定义的 data 属性 data-toggle 用于打开模态窗口。

运行结果:

1.静态页面
在这里插入图片描述
2.点击按钮
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值