嗨害嗨,我又来了奥。今天呢,给大家分享一个工作中常用到的插件——模态对话框的用法。想必大家在工作中也遇到很多页面,需要用模态对话框进行交互的吧,现在呢,就让我们一起来了解一下它的使用吧。
首先,我们得准备三个文件,bootstrap的css文件,bootstrap的js文件,以及jQuery的js文件。
在head里面引入三行文件,如下所示:
<link rel="stylesheet" href="../vendor/bootstrap.css">
<script src="../vendor/jquery-3.6.0.js"></script>
<script src="../vendor/bootstrap.bundle.js"></script>
然后,我们去官网,把bootstrap的代码拷过来,做一个cv战神。我呢,将它的代码里的内容做了下修改,因为我现在要说的就是在这个基础上完成一系列操作。我将里面的文字改成了输入框,毕竟做项目,做的就是用户与输入框之间的交互,对吧?
html代码如下所示:
<button class="btn evidence_show btn btn-success" id="btn1">点我打开模态框</button>
<p id="word"></p>
<!-- 模态框(Modal) -->
<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true"
onclick="close_bg()">×</button>
<h4 class="modal-title" id="myModalLabel">模态框(Modal)标题</h4>
</div>
<div class="modal-body">
<input id="inp" value="" type="text">
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" onclick="close_bg()" data-dismiss="modal">关闭</button>
<button type="button" onclick="submit()" class="btn btn-primary">提交更改</button>
</div>
</div><!-- /.modal-content -->
</div><!-- /.modal -->
</div>
模态框默认是隐藏的,当我们打开以后,它长这样:
对话框左上角的叉叉和右下方的关闭,点击对应的方法是close_bg,表示关闭这个模态对话框,就是把他给隐藏了。点击按钮,打开(显示)这个模态对话框。我们在左边弄一个p标签,用来保存提交后的值。
1.点击按钮,打开模态框,输入框的值就是外面这个p标签的innerHTML。
2.点击叉叉或者关闭,先将输入框的内容清空,然后关闭隐藏这个模态对话框。
3.点击提交,将输入框的值赋值给外面这个p标签的innerHTML,再隐藏掉这个模态对话框。
这只是前端的交互,并没有向后端调接口。在工作中,我们的思路就是:
1.点击编辑按钮,弹出模态对话框,输入框的值调取后端接口,显示出来。
2.点击叉叉或者关闭,先清空输入框的内容,然后关闭隐藏这个模态对话框。
3.点击提交,调取接口,利用post方法,将框内的数据按照后端接口的形式传递过去,从而修改数据库中的值,最后再关闭隐藏这个输入框。
话不多说,我这先上个不涉及调接口的代码,大家应该能写出调取接口的代码了吧。
<script>
$("#btn1").click(function () {
//显示模态框
$("#myModal").modal('show')
//输入框的值为p的html
$("#inp").val($("#word").html())
})
function close_bg() {
//点击关闭,就要清空输入框内容
$("#inp").val('')
//关闭模态框
$("#myModal").modal('hide')
}
function submit() {
//得到输入框的值,赋值出来
$("#word").html($("#inp").val())
//关闭模态框
$("#myModal").modal('hide')
}
</script>
好啦,今天的内容就分享到这,大家去试一下吧。下次见