在项目中可能会面对这样的一个场景:

界面上有多个按钮,我们希望点击这些按钮弹出同一个模态窗口,但希望模态窗口的内容是动态生成的,即,点击每个按钮弹出的模态窗口内容不同。

通常情况下,一个按钮对应一个模态窗口。

  1. <head>
  2.  
  3.     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  4.  
  5.     <title></title>
  6.  
  7.     <link href="css/bootstrap.min.css" rel="stylesheet" />
  8.  
  9.     <script src="Scripts/jquery-2.1.1.min.js"></script>
  10.  
  11.     <script src="js/bootstrap.min.js"></script>
  12.  
  13.     <style type="text/css">
  14.  
  15.         body.modal-open,
  16.  
  17.         .modal-open .navbar-fixed-top,
  18.  
  19.         .modal-open .navbar-fixed-bottom {
  20.  
  21.             margin-right: 0;
  22.  
  23.         }
  24.  
  25.         .modal {
  26.  
  27.             top: 100px;
  28.  
  29.             bottom: auto;
  30.  
  31.             padding: 0;
  32.  
  33.             background-color: #ffffff;
  34.  
  35.             border: 1px solid #999999;
  36.  
  37.             border: 1px solid rgba(0, 0, 0, 0.2);
  38.  
  39.             border-radius: 6px;
  40.  
  41.             -webkit-box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
  42.  
  43.             box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
  44.  
  45.             background-clip: padding-box;
  46.  
  47.         }
  48.  
  49.         .modal.container {
  50.  
  51.             max-width: none;
  52.  
  53.         }
  54.  
  55.     </style>
  56.  
  57. </head>
  58.  
  59.     <body>
  60.  
  61.         <div class="content" style="margin-left: 100px;margin-top: 100px;">
  62.  
  63.             <button class="btn btn-primary btn-lg" data-toggle="modal" href="#full-width">打开模态窗口</button>
  64.  
  65.         </div>
  66.  
  67.         <div id="full-width" class="modal container fade" tabindex="-1" style="display: none;">
  68.  
  69.             <div class="modal-header">
  70.  
  71.                 <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
  72.  
  73.                 <h4 class="modal-title">标题</h4>
  74.  
  75.             </div>
  76.  
  77.             <div class="modal-body">
  78.  
  79.                 <p>
  80.  
  81.                     主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容
  82.  
  83.                 </p>
  84.  
  85.             </div>
  86.  
  87.             <div class="modal-footer" style="text-align: center;">
  88.  
  89.                 <button type="button" data-dismiss="modal" class="btn btn-default">关闭</button>
  90.  
  91.             </div>
  92.  
  93.         </div>
  94.  
  95.     </body>
  96.  

效果如下:

以上,通过data-toggle="modal" href="#full-width"实现模态窗口。

现在,在页面上存在2个按钮:

  1. <button class="btn btn-primary btn-lg">打开模态窗口1</button>
  2.  
  3. <button class="btn btn-primary btn-lg">打开模态窗口2</button>

我们希望点击每个按钮都弹出id为full-width的模态窗口,但模态窗口的标题为按钮的文本。

于是,需要通过Javascript的API来弹出模态窗口,并且,在弹出之前需要把按钮的文本赋值给模态窗口的标题。

  1.         $(function() {
  2.  
  3.             $('.content').on("click", "button", function () {
  4.  
  5.                 $('#full-width .modal-header .modal-title').empty().text($(this).text());
  6.  
  7.                 $('#full-width').modal();
  8.  
  9.             });
  10.  
  11.         });

完整如下:

  1. <head>
  2.  
  3.     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  4.  
  5.     <title></title>
  6.  
  7.     <link href="css/bootstrap.min.css" rel="stylesheet" />
  8.  
  9.     <script src="Scripts/jquery-2.1.1.min.js"></script>
  10.  
  11.     <script src="js/bootstrap.min.js"></script>
  12.  
  13.     <style type="text/css">
  14.  
  15.         body.modal-open,
  16.  
  17.         .modal-open .navbar-fixed-top,
  18.  
  19.         .modal-open .navbar-fixed-bottom {
  20.  
  21.             margin-right: 0;
  22.  
  23.         }
  24.  
  25.         .modal {
  26.  
  27.             top: 100px;
  28.  
  29.             bottom: auto;
  30.  
  31.             padding: 0;
  32.  
  33.             background-color: #ffffff;
  34.  
  35.             border: 1px solid #999999;
  36.  
  37.             border: 1px solid rgba(0, 0, 0, 0.2);
  38.  
  39.             border-radius: 6px;
  40.  
  41.             -webkit-box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
  42.  
  43.             box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
  44.  
  45.             background-clip: padding-box;
  46.  
  47.         }
  48.  
  49.         .modal.container {
  50.  
  51.             max-width: none;
  52.  
  53.         }
  54.  
  55.     </style>
  56.  
  57.     <script type="text/javascript">
  58.  
  59.         $(function() {
  60.  
  61.             $('.content').on("click", "button", function () {
  62.  
  63.                 $('#full-width .modal-header .modal-title').empty().text($(this).text());
  64.  
  65.                 $('#full-width').modal();
  66.  
  67.             });
  68.  
  69.         });
  70.  
  71.     </script>
  72.  
  73. </head>
  74.  
  75.     <body>
  76.  
  77.         <div class="content" style="margin-left: 100px;margin-top: 100px;">
  78.  
  79.             <button class="btn btn-primary btn-lg">打开模态窗口1</button>
  80.  
  81.             <button class="btn btn-primary btn-lg">打开模态窗口2</button>
  82.  
  83.         </div>
  84.  
  85.         <div id="full-width" class="modal container fade" tabindex="-1" style="display: none;">
  86.  
  87.             <div class="modal-header">
  88.  
  89.                 <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
  90.  
  91.                 <h4 class="modal-title">标题</h4>
  92.  
  93.             </div>
  94.  
  95.             <div class="modal-body">
  96.  
  97.                 <p>
  98.  
  99.                     主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容主体内容
  100.  
  101.                 </p>
  102.  
  103.             </div>
  104.  
  105.             <div class="modal-footer" style="text-align: center;">
  106.  
  107.                 <button type="button" data-dismiss="modal" class="btn btn-default">关闭</button>
  108.  
  109.             </div>
  110.  
  111.         </div>
  112.  
  113.     </body>
  114.  

效果如下:

多个按钮触发同一个Bootstrap自适应模态窗口的更多相关文章

  1. 使用jQuery和Bootstrap实现多层、自适应模态窗口

    本篇实践一个多层模态窗口,而且是自适应的. 点击页面上的一个按钮,弹出第一层自适应模态窗口. 在第一层模态窗口内包含一个按钮,点击该按钮弹出第二层模态窗口,弹出的第二层模态窗口会挡住第一层模态窗口,即 ...

  2. bootstrap 自定义模态窗口

    $(".classname").click(function () { $('#mymodel').modal('show'); alert('模态框打开了'); }); $('# ...

  3. BootStrap入门教程 (四) :JQuery类库插件(模态窗口,滚动监控,标签效果,提示效果,“泡芙”效果,警告区域,折叠效果,旋转木马,输入提示)

    上讲回顾:Bootstrap组件丰富同时具有良好可扩展性,能够很好地应用在生产环境.这些组件包括按钮(Button),导航(Navigation),缩略图( thumbnails),提醒(Alert) ...

  4. bootstrap 模态窗口 多重/多个弹窗滚动条补丁

    由于bootstrap的模态窗口默认不支持多次弹出, 在关闭的时候会有滚动条消失的问题. 经过观察和查看源码, 发现在开启和关闭的时候会在body上增加/减少一个"modal-open&qu ...

  5. WebUploader 上传插件结合bootstrap的模态框使用时选择上传文件按钮无效问题的解决方法

    由于种种原因(工作忙,要锻炼健身,要看书,要学习其他兴趣爱好,谈恋爱等),博客已经好久没有更新,为这个内心一直感觉很愧疚,今天开始决定继续更新博客,每周至少一篇,最多不限篇幅. 今天说一下,下午在工作 ...

  6. Bootstrap 实例 - 模态框(Modal)插件

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  7. bootstrap的模态框

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  8. layui实现类似于bootstrap的模态框功能

    以前习惯了bootstrap的模态框,突然换了layui,想的用layui实现类似于bootstrap的模态框功能. 用到了layui的layer模块,例如: <!DOCTYPE html> ...

  9. Bootstrap使用模态框modal实现表单提交弹出框

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

随机推荐

  1. js 替换任意字符串中间几位为*星号

    <script> var str='河南纳智企业管理咨询有限公司'; a=str.substr(0,2)+'***'+str.substr(5,str.split('').length); ...

  2. oracle数据库_实例_用户_表空间之间的关系

    基础概念:Oracle数据库.实例.用户.表空间.表之间的关系 数据库:Oracle数据库是数据的物理存储.这就包括(数据文件ORA或者DBF.控制文件.联机日志.参数文件).其实Oracle数据库的 ...

  3. laravel 5.1 Model 属性详解

    <?php namespace Illuminate\Database\Eloquent; /** * 下面提到某些词的含义: * 1.覆盖: 在继承该类 \Illuminate\Databas ...

  4. 深度剖析:PHP中json_encode与json_decode

    一.json_encode() 对变量进行JSON编码, 语法: json_encode ( $value [, $options = 0 ] ) 注意:1.$value为要编码的值,且该函数只对UT ...

  5. Java编程的逻辑 (19) - 接口的本质

    本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...

  6. zabbix3.4+grafana5.0.1数据可视化

    转自:https://blog.csdn.net/xiaoying5191/article/details/79530280

  7. VS2010中设置程序以管理员身份运行

    VS2010中设置程序以管理员身份运行 直接项目右键---属性---连接器---清单文件---uac执行级别 选择requireAdministrator 重新编译 即可 这样程序直接运行就拥有管理员 ...

  8. P2858 [USACO06FEB]奶牛零食Treats for the Cows

    P2858 [USACO06FEB]奶牛零食Treats for the Cows区间dp,级像矩阵取数, f[i][i+l]=max(f[i+1][i+l]+a[i]*(m-l),f[i][i+l- ...

  9. q.size()

    在队列中,q.empty()比q.size()要慢,如果可能就用q.size(); 比如spfa的 while(q.size()>0) better than while(!q.empty())

  10. [转]关于一些SPFA的标程

    SPFA算法 求单源最短路的SPFA算法的全称是:Shortest Path Faster Algorithm. 最短路径快速算法-SPFA算法是西南交通大学段凡丁于1994年发表的. 适用范围:给定 ...