Pembaruan untuk 2018 - Menggunakan Bootstrap 4
Saya menemukan sebagian besar jawaban tampaknya memiliki banyak jQuery yang tidak perlu. Untuk membuka modal dari modal lain dapat dilakukan hanya dengan menggunakan event yang disediakan Bootstrap seperti show.bs.modal
. Anda mungkin juga menginginkan beberapa CSS untuk menangani hamparan tampilan latar. Berikut adalah 3 modal terbuka dari skenario lain ...
Buka modal dari modal lain (biarkan modal pertama tetap terbuka)
<a data-toggle="modal" href="#myModal" class="btn btn-primary">Launch modal</a>
<div class="modal" id="myModal">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h4 class="modal-title">Modal title</h4>
<button type="button" class="close" data-dismiss="modal">×</button>
</div><div class="container"></div>
<div class="modal-body">
...
<a data-toggle="modal" href="#myModal2" class="btn btn-primary">Open modal2</a>
</div>
<div class="modal-footer">
<a href="#" data-dismiss="modal" class="btn">Close</a>
</div>
</div>
</div>
</div>
<div class="modal" id="myModal2" data-backdrop="static">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h4 class="modal-title">2nd Modal title</h4>
<button type="button" class="close" data-dismiss="modal">×</button>
</div><div class="container"></div>
<div class="modal-body">
..
</div>
<div class="modal-footer">
<a href="#" data-dismiss="modal" class="btn">Close</a>
<a href="#" class="btn btn-primary">Save changes</a>
</div>
</div>
</div>
</div>
Masalah potensial dalam kasus ini adalah bahwa latar belakang dari modal ke-2 menyembunyikan modal pertama. Untuk mencegahnya, buat modal ke-2 data-backdrop="static"
, dan tambahkan beberapa CSS untuk memperbaiki indeks-z dari latar belakang ...
/* modal backdrop fix */
.modal:nth-of-type(even) {
z-index: 1052 !important;
}
.modal-backdrop.show:nth-of-type(even) {
z-index: 1051 !important;
}
https://www.codeply.com/go/NiFzSCukVl
Buka modal dari modal lain (tutup modal pertama)
Ini mirip dengan skenario di atas, tetapi karena kita menutup modal pertama saat modal kedua dibuka, tidak diperlukan perbaikan CSS latar belakang. Fungsi sederhana yang menangani modal ke-2show.bs.modal
event menutup modal pertama.
$("#myModal2").on('show.bs.modal', function (e) {
$("#myModal1").modal("hide");
});
https://www.codeply.com/go/ejaUJ4YANz
Buka modal di dalam modal lain
Skenario beberapa modal terakhir adalah membuka modal ke-2 di dalam modal pertama. Dalam hal ini markup untuk yang ke-2 ditempatkan di dalam yang ke-1. Tidak diperlukan CSS atau jQuery tambahan.
<div class="modal" id="myModal1">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h4 class="modal-title">Modal title</h4>
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
</div>
<div class="container"></div>
<div class="modal-body">
...
<a data-toggle="modal" href="#myModal2" class="btn btn-primary">Launch modal 2</a>
</div>
<div class="modal-footer">
<a href="#" data-dismiss="modal" class="btn">Close</a>
</div>
</div>
</div>
<div class="modal" id="myModal2">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h4 class="modal-title">2nd Modal title</h4>
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
</div>
<div class="container"></div>
<div class="modal-body">
...
</div>
<div class="modal-footer">
<a href="#" data-dismiss="modal" class="btn">Close</a>
<a href="#" class="btn btn-primary">Save changes</a>
</div>
</div>
</div>
</div>
</div>
https://www.codeply.com/go/iSbjqubiyn