bootstrap中的模態框(modal,彈出層)

bootstrap中的模態框(modal),不一樣於Tooltips,模態框以彈出對話框的形式出現,具備最小和最實用的功能集。javascript

務必將模態框的 HTML 代碼放在文檔的最高層級內(也就是說,儘可能做爲 body 標籤的直接子元素),以免其餘組件影響模態框的展示或功能。css

默認的modal示例:html

[html]  view plain  copy
 
  1. <!DOCTYPE html>  
  2. <html lang="zh-CN">  
  3. <head>  
  4.     <meta charset="utf-8">  
  5.     <meta http-equiv="X-UA-Compatible" content="IE=edge">  
  6.     <meta name="viewport" content="width=device-width, initial-scale=1">  
  7.     <title>Bootstrap Modal</title>  
  8.     <link rel="stylesheet" href="http://cdn.bootcss.com/bootstrap/3.3.5/css/bootstrap.min.css">  
  9. </head>  
  10. <body>  
  11. <button type="button" class="btn btn-primary btn-lg" data-toggle="modal" data-target="#myModal">  
  12.     Launch demo modal  
  13. </button>  
  14.   
  15. <div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">  
  16.     <div class="modal-dialog" role="document">  
  17.         <div class="modal-content">  
  18.             <div class="modal-header">  
  19.                 <button type="button" class="close" data-dismiss="modal" aria-label="Close">  
  20.                     <span aria-hidden="true"</span>  
  21.                 </button>  
  22.                 <h4 class="modal-title" id="myModalLabel">Modal title</h4>  
  23.             </div>  
  24.             <div class="modal-body">  
  25.                 <p>One fine body…</p>  
  26.             </div>  
  27.             <div class="modal-footer">  
  28.                 <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>  
  29.                 <button type="button" class="btn btn-primary">Save</button>  
  30.             </div>  
  31.         </div>  
  32.     </div>  
  33. </div>  
  34.   
  35. <script src="http://cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script>  
  36. <script src="http://cdn.bootcss.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>  
  37. </body>  
  38. </html>  
  1. 爲 .modal 添加 role="dialog",用於指定模態框爲對話框。
  2. 爲 .modal-dialog 添加 aria-hidden="true" 屬性。
  3. 經過 aria-describedby 屬性爲模態框 .modal 添加描述性信息。

關閉動畫java

若是你不須要模態框彈出時的動畫效果(淡入淡出效果),刪掉 .fade 類便可。jquery


經過按鈕屬性顯示不一樣內容
當有一堆按鈕,都要觸發相同的模態框(如:向好友列表中某我的發消息),只是有用戶ID不一樣,那麼可使用data-whatever配合event.relatedtarget來實現:ajax

[html]  view plain  copy
 
  1. <!DOCTYPE html>  
  2. <html lang="zh-CN">  
  3. <head>  
  4.     <meta charset="utf-8">  
  5.     <meta http-equiv="X-UA-Compatible" content="IE=edge">  
  6.     <meta name="viewport" content="width=device-width, initial-scale=1">  
  7.     <title>Bootstrap Modal</title>  
  8.     <link rel="stylesheet" href="http://cdn.bootcss.com/bootstrap/3.3.5/css/bootstrap.min.css">  
  9. </head>  
  10. <body>  
  11.   
  12.   
  13. <div class="panel panel-default">  
  14.     <div class="panel-heading">好友列表</div>  
  15.     <div class="panel-body">  
  16.         <div class="list-group" role="group" aria-label="好友列表">  
  17.             <button type="button" class="list-group-item" data-toggle="modal" data-target="#exampleModal"  
  18.                     data-whatever="張三">張三  
  19.             </button>  
  20.             <button type="button" class="list-group-item" data-toggle="modal" data-target="#exampleModal"  
  21.                     data-whatever="李四">李四  
  22.             </button>  
  23.             <button type="button" class="list-group-item" data-toggle="modal" data-target="#exampleModal"  
  24.                     data-whatever="王二">王二  
  25.             </button>  
  26.         </div>  
  27.     </div>  
  28. </div>  
  29.   
  30. <div class="modal fade" id="exampleModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel">  
  31.     <div class="modal-dialog" role="document">  
  32.         <div class="modal-content">  
  33.             <div class="modal-header">  
  34.                 <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span  
  35.                         aria-hidden="true"</span></button>  
  36.                 <h4 class="modal-title" id="exampleModalLabel">New message</h4>  
  37.             </div>  
  38.             <div class="modal-body">  
  39.                 <form>  
  40.                     <div class="form-group">  
  41.                         <label for="recipient-name" class="control-label">Recipient:</label>  
  42.                         <input type="text" class="form-control" id="recipient-name">  
  43.                     </div>  
  44.                     <div class="form-group">  
  45.                         <label for="message-text" class="control-label">Message:</label>  
  46.                         <textarea class="form-control" id="message-text"></textarea>  
  47.                     </div>  
  48.                 </form>  
  49.             </div>  
  50.             <div class="modal-footer">  
  51.                 <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>  
  52.                 <button type="button" class="btn btn-primary">Send message</button>  
  53.             </div>  
  54.         </div>  
  55.     </div>  
  56. </div>  
  57. <script src="http://cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script>  
  58. <script src="http://cdn.bootcss.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>  
  59. <script>  
  60.     $('#exampleModal').on('show.bs.modal', function (event) {  
  61.         var button = $(event.relatedTarget) // 觸發事件的按鈕  
  62.         var recipient = button.data('whatever') // 解析出data-whatever內容  
  63.         var modal = $(this)  
  64.         modal.find('.modal-title').text('Message To ' + recipient)  
  65.         modal.find('.modal-body input').val(recipient)  
  66.     })  
  67. </script>  
  68. </body>  
  69. </html>  

 

一般不需寫 JavaScript 代碼也可激活模態框。經過在一個起控制器做用的元素(例如:按鈕)上添加 data-toggle="modal" 屬性,或者 data-target="#foo" 屬性,再或者 href="#foo" 屬性,用於指向被控制的模態框。

bootstrap

經過JavaScript調用modalide

一般只需一行 javascript 代碼,便可經過元素的 id myModal 調用模態框:函數

 

[html]  view plain  copy
 
  1. $('#myModal').modal(options)  

 

JavaScript參數動畫

能夠將選項經過 data 屬性或 JavaScript 代碼傳遞。對於 data 屬性,須要將參數名稱放到 data- 以後,例如 data-backdrop=""。

 

名稱 類型 默認值 描述
backdrop boolean或'static' true 默認狀況下,點擊其它位置,模態框自動關閉,你能夠設置此屬性爲false或者"static"防止模態框自動關閉
keyboard boolean true 鍵盤上的 esc 鍵被按下時關閉模態框。
show path true 模態框初始化以後就當即顯示出來。
remote path false 這個參數在v4裏會去掉(能夠本身寫ajax請求來實現)若是提供的是 URL,將利用 jQuery 的 load 方法今後 URL 地址加載要展現的內容(只加載一次)並插入 .modal-content 內。若是使用的是 data 屬性 API,還能夠利用 href 屬性指定內容來源地址。下面是一個實例:
<a data-toggle="modal" href="remote.html" data-target="#modal">Click me</a>

 

    

調用示例
1.將頁面中的某塊內容做爲模態框激活。接受可選參數 object。

[html]  view plain  copy
 
  1. $('#myModal').modal({  
  2.   keyboard: false  
  3. })  


2.手動打開或關閉模態框。在模態框顯示或隱藏以前返回到主調函數中(也就是,在觸發 shown.bs.modal 或 hidden.bs.modal 事件以前)。

[html]  view plain  copy
 
  1. $('#myModal').modal('toggle')  


3.手動打開模態框。在模態框顯示以前返回到主調函數中 (也就是,在觸發 shown.bs.modal 事件以前)。

[html]  view plain  copy
 
  1. $('#myModal').modal('show')  


4.手動隱藏模態框。在模態框隱藏以前返回到主調函數中 (也就是,在觸發 hidden.bs.modal 事件以前)。

[html]  view plain  copy
 
  1. $('#myModal').modal('hide')  


5.更新模態框,在模態框動態添加或刪除內容時:

[html]  view plain  copy
 
  1. $('#myModal').modal('handleUpdate')  


綁定事件
Bootstrap 的模態框類提供了一些事件用於監聽並執行你本身的代碼。

事件類型 描述
show.bs.modal show 方法調用以後當即觸發該事件。若是是經過點擊某個做爲觸發器的元素,則此元素能夠經過事件的 relatedTarget 屬性進行訪問。
shown.bs.modal 此事件在模態框已經顯示出來(而且同時在 CSS 過渡效果完成)以後被觸發。若是是經過點擊某個做爲觸發器的元素,則此元素能夠經過事件的 relatedTarget 屬性進行訪問。
hide.bs.modal hide 方法調用以後當即觸發該事件。
hidden.bs.modal 此事件在模態框被隱藏(而且同時在 CSS 過渡效果完成)以後被觸發。
loaded.bs.modal 從遠端的數據源加載完數據以後觸發該事件。

如:

[html]  view plain  copy
 
    1. $('#myModal').on('hidden.bs.modal', function (e) {  
    2.   // do something...  
    3. })  
相關文章
相關標籤/搜索