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">
×
</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 ที่ถูกต้องก็จะโหลดเนื้อหานั้น ตัวอย่างนี้แสดงไว้ด้านล่าง - |
วิธีการ
นี่คือวิธีการที่มีประโยชน์บางอย่างที่สามารถใช้กับ modal ()
วิธี | คำอธิบาย | ตัวอย่าง |
---|---|---|
Options - .modal (ตัวเลือก) | เปิดใช้งานเนื้อหาของคุณเป็นโมดอล ยอมรับอ็อบเจ็กต์อ็อพชันเสริม | |
Toggle - .modal ('สลับ') | สลับโมดอลด้วยตนเอง | |
Show - .modal ('แสดง') | เปิดโมดอลด้วยตนเอง | |
Hide - .modal ('ซ่อน') | ซ่อนโมดอลด้วยตนเอง | |
ตัวอย่าง
ตัวอย่างต่อไปนี้แสดงให้เห็นถึงการใช้วิธีการ -
<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 | เริ่มทำงานหลังจากเรียกวิธีการแสดง | |
shown.bs.modal | เริ่มทำงานเมื่อผู้ใช้มองเห็นโมดอล (จะรอให้การเปลี่ยน CSS เสร็จสมบูรณ์) | |
hide.bs.modal | เริ่มทำงานเมื่อมีการเรียกวิธีการซ่อนอินสแตนซ์ | |
hidden.bs.modal | เริ่มทำงานเมื่อโมดอลเสร็จสิ้นถูกซ่อนจากผู้ใช้ | |
ตัวอย่าง
ตัวอย่างต่อไปนี้แสดงให้เห็นถึงการใช้งานเหตุการณ์ -
<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>
ดังที่เห็นในหน้าจอด้านบนหากคุณคลิกที่ปุ่มปิดเช่นซ่อนเหตุการณ์ข้อความแจ้งเตือนจะปรากฏขึ้น