Bootstrap - ปลั๊กอิน Modal

โมดอลคือหน้าต่างลูกที่อยู่เหนือหน้าต่างพาเรนต์ โดยทั่วไปจุดประสงค์คือเพื่อแสดงเนื้อหาจากแหล่งที่มาแยกต่างหากที่สามารถมีปฏิสัมพันธ์บางอย่างได้โดยไม่ต้องออกจากหน้าต่างหลัก หน้าต่างลูกสามารถให้ข้อมูลการโต้ตอบหรืออื่น ๆ

หากคุณต้องการรวมฟังก์ชันปลั๊กอินนี้แยกกันคุณจะต้องมี modal.js. อื่น ๆ ตามที่กล่าวไว้ในบท Bootstrap ปลั๊กอินภาพรวมคุณสามารถรวม bootstrap.jsหรือลดขนาดลง bootstrap.min.js

การใช้งาน

คุณสามารถสลับเนื้อหาที่ซ่อนอยู่ของปลั๊กอินโมดอล -

  • Via data attributes - ตั้งค่าแอตทริบิวต์ data-toggle = "modal" บนองค์ประกอบตัวควบคุมเช่นปุ่มหรือลิงก์พร้อมกับไฟล์ data-target = "#identifier" หรือ href = "#identifier" เพื่อกำหนดเป้าหมายโมดอลเฉพาะ (ด้วย id = "identifier") เพื่อสลับ

  • Via JavaScript - การใช้เทคนิคนี้คุณสามารถเรียกโมดอลด้วย id = "ตัวระบุ" ด้วย JavaScript บรรทัดเดียว -

$('#identifier').modal(options)

ตัวอย่าง

ตัวอย่างหน้าต่างโมดอลแบบคงที่แสดงในตัวอย่างต่อไปนี้ -

<h2>Example of creating Modals with Twitter Bootstrap</h2>

<!-- Button trigger modal -->
<button class = "btn btn-primary btn-lg" data-toggle = "modal" data-target = "#myModal">
   Launch demo modal
</button>

<!-- 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">
                  &times;
            </button>
            
            <h4 class = "modal-title" id = "myModalLabel">
               This Modal title
            </h4>
         </div>
         
         <div class = "modal-body">
            Add some text here
         </div>
         
         <div class = "modal-footer">
            <button type = "button" class = "btn btn-default" data-dismiss = "modal">
               Close
            </button>
            
            <button type = "button" class = "btn btn-primary">
               Submit changes
            </button>
         </div>
         
      </div><!-- /.modal-content -->
   </div><!-- /.modal-dialog -->
  
</div><!-- /.modal -->

Details of the preceding code −

  • ในการเรียกใช้หน้าต่างโมดอลคุณต้องมีทริกเกอร์บางประเภท คุณสามารถใช้ปุ่มหรือลิงค์ ที่นี่เราได้ใช้ปุ่ม

  • หากคุณดูในโค้ดด้านบนคุณจะเห็นว่าในแท็ก <button> แท็ก data-target = "#myModal"คือเป้าหมายของโมดอลที่คุณต้องการโหลดบนหน้า รหัสนี้ช่วยให้คุณสามารถสร้างโมดอลหลายรายการบนเพจจากนั้นจึงมีทริกเกอร์ที่แตกต่างกันสำหรับแต่ละโหมด ตอนนี้เพื่อความชัดเจนคุณไม่ได้โหลดหลายโมดอลในเวลาเดียวกัน แต่คุณสามารถสร้างหลาย ๆ หน้าเพื่อโหลดในเวลาที่ต่างกัน

  • มีสองคลาสที่ควรทราบในโมดอล -

    • ประการแรกคือ .modalซึ่งเป็นเพียงการระบุเนื้อหาของ <div> เป็นโมดอล

    • และประการที่สองคือ .fadeชั้นเรียน เมื่อมีการสลับโมดอลจะทำให้เนื้อหาจางเข้าและออก

  • aria-labelledby = "myModalLabel"แอตทริบิวต์อ้างอิงหัวเรื่องโมดอล

  • แอตทริบิวต์ aria-hidden = "true" ใช้เพื่อไม่ให้หน้าต่าง Modal มองไม่เห็นจนกว่าจะมีทริกเกอร์มา (เช่นการคลิกที่ปุ่มที่เกี่ยวข้อง)

  • <div class = "modal-header">, modal-header คือคลาสสำหรับกำหนดสไตล์สำหรับส่วนหัวของหน้าต่างโมดอล

  • class = "close"เป็นคลาสปิด CSS ที่กำหนดรูปแบบสำหรับปุ่มปิดของหน้าต่างโมดอล

  • data-dismiss = "modal"เป็นแอตทริบิวต์ข้อมูล HTML5 ที่กำหนดเอง ที่นี่ใช้เพื่อปิดหน้าต่างโมดอล

  • class = "modal-body"เป็นคลาส CSS ของ Bootstrap CSS เพื่อกำหนดสไตล์สำหรับเนื้อความของหน้าต่างโมดอล

  • class = "modal-footer"เป็นคลาส CSS ของ Bootstrap CSS เพื่อกำหนดรูปแบบสำหรับส่วนท้ายของหน้าต่างโมดอล

  • data-toggle = "modal"HTML5 แอตทริบิวต์ข้อมูลที่กำหนดเอง data-toggle ใช้เพื่อเปิดหน้าต่างโมดอล

ตัวเลือก

มีตัวเลือกบางอย่างที่สามารถส่งผ่านแอตทริบิวต์ข้อมูลหรือ JavaScript เพื่อปรับแต่งรูปลักษณ์ของหน้าต่าง Modal ตารางต่อไปนี้แสดงรายการตัวเลือก -

ชื่อตัวเลือก ประเภท / ค่าเริ่มต้น ชื่อแอตทริบิวต์ข้อมูล คำอธิบาย
ฉากหลัง บูลีนหรือสตริง "คงที่" ค่าเริ่มต้น: จริง ข้อมูลฉากหลัง ระบุสแตติกสำหรับฉากหลังหากคุณไม่ต้องการให้โมดอลปิดเมื่อผู้ใช้คลิกนอกโมดอล
แป้นพิมพ์ บูลีนดีฟอลต์: จริง แป้นพิมพ์ข้อมูล ปิดโมดอลเมื่อกดปุ่ม Escape ตั้งค่าเป็นเท็จเพื่อปิดใช้งาน
แสดง บูลีนดีฟอลต์: จริง แสดงข้อมูล แสดงโมดอลเมื่อเริ่มต้น
ระยะไกล เส้นทางเริ่มต้น: เท็จ ข้อมูลระยะไกล

ใช้วิธี jQuery .loadฉีดเนื้อหาลงในตัวโมดอล หากเพิ่ม href ที่มี URL ที่ถูกต้องก็จะโหลดเนื้อหานั้น ตัวอย่างนี้แสดงไว้ด้านล่าง -

<a data-toggle = "modal" href = "remote.html" data-target = "#modal">Click me</a>

วิธีการ

นี่คือวิธีการที่มีประโยชน์บางอย่างที่สามารถใช้กับ modal ()

วิธี คำอธิบาย ตัวอย่าง
Options - .modal (ตัวเลือก) เปิดใช้งานเนื้อหาของคุณเป็นโมดอล ยอมรับอ็อบเจ็กต์อ็อพชันเสริม
$('#identifier').modal({
   keyboard: false
})
Toggle - .modal ('สลับ') สลับโมดอลด้วยตนเอง
$('#identifier').modal('toggle')
Show - .modal ('แสดง') เปิดโมดอลด้วยตนเอง
$('#identifier').modal('show')
Hide - .modal ('ซ่อน') ซ่อนโมดอลด้วยตนเอง
$('#identifier').modal('hide')

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงให้เห็นถึงการใช้วิธีการ -

<h2>Example of using methods of Modal Plugin</h2>

<!-- Button trigger modal -->
<button class = "btn btn-primary btn-lg" data-toggle = "modal" data-target = "#myModal">
   Launch demo modal
</button>

<!-- 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">
               ×
            </button>
            
            <h4 class = "modal-title" id = "myModalLabel">
               This Modal title
            </h4>
         </div>
         
         <div class = "modal-body">
            Press ESC button to exit.
         </div>
         
         <div class = "modal-footer">
            <button type = "button" class = "btn btn-default" data-dismiss = "modal">
               Close
            </button>
            
            <button type = "button" class = "btn btn-primary">
               Submit changes
            </button>
         </div>
         
      </div><!-- /.modal-content -->
   </div><!-- /.modal-dialog -->
   
</div><!-- /.modal -->

<script>
   $(function () { $('#myModal').modal({
      keyboard: true
   })});
</script>

เพียงคลิกปุ่ม Esc จากนั้นหน้าต่างโมดอลจะออก

เหตุการณ์

ตารางต่อไปนี้แสดงรายการเหตุการณ์ที่จะทำงานกับโมดอล เหตุการณ์เหล่านี้อาจใช้เพื่อเชื่อมต่อกับฟังก์ชัน

เหตุการณ์ คำอธิบาย ตัวอย่าง
show.bs.modal เริ่มทำงานหลังจากเรียกวิธีการแสดง
$('#identifier').on('show.bs.modal', function () {
   // do something…
})
shown.bs.modal เริ่มทำงานเมื่อผู้ใช้มองเห็นโมดอล (จะรอให้การเปลี่ยน CSS เสร็จสมบูรณ์)
$('#identifier').on('shown.bs.modal', function () {
   // do something…
})
hide.bs.modal เริ่มทำงานเมื่อมีการเรียกวิธีการซ่อนอินสแตนซ์
$('#identifier').on('hide.bs.modal', function () {
   // do something…
})
hidden.bs.modal เริ่มทำงานเมื่อโมดอลเสร็จสิ้นถูกซ่อนจากผู้ใช้
$('#identifier').on('hidden.bs.modal', function () {
   // do something…
})

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงให้เห็นถึงการใช้งานเหตุการณ์ -

<h2>Example of using events of Modal Plugin</h2>

<!-- Button trigger modal -->
<button class = "btn btn-primary btn-lg" data-toggle = "modal" data-target = "#myModal">
   Launch demo modal
</button>

<!-- 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">
               ×
            </button>
            
            <h4 class = "modal-title" id = "myModalLabel">
               This Modal title
            </h4>
         </div>
         
         <div class = "modal-body">
            Click on close button to check Event functionality.
         </div>
         
         <div class = "modal-footer">
            <button type = "button" class = "btn btn-default" data-dismiss = "modal">
               Close
            </button>
            
            <button type = "button" class = "btn btn-primary">
               Submit changes
            </button>
         </div>
         
      </div><!-- /.modal-content -->
   </div><!-- /.modal-dialog -->
   
</div><!-- /.modal -->

<script>
   $(function () { $('#myModal').modal('hide')})});
</script>

<script>
   $(function () { $('#myModal').on('hide.bs.modal', function () {
      alert('Hey, I heard you like modals...');})
   });
</script>

ดังที่เห็นในหน้าจอด้านบนหากคุณคลิกที่ปุ่มปิดเช่นซ่อนเหตุการณ์ข้อความแจ้งเตือนจะปรากฏขึ้น