Categories: JavascriptTips Trik

Tombol back tutup modal bootstrap tanpa kembali ke halaman sebelumnya

Bismillaahirrohmaanirrohiim…

Jika kita membuat aplikasi web base menggunakan bootstrap, saat user membuka modal, kadangkala mereka lupa kalo tombol back akan kembali ke halaman sebelumnya, padahal inginnya hanya menutup modal saja.

Nah kode untuk menangani aksi back user jika modal terbuka adalah sebagai berikut:

// Simpan modal yang sedang terbuka
        let modalOpened = false;
        let activeModalId = null;

        // Saat modal ditampilkan
        $(document).on('shown.bs.modal', '.modal', function () {
            modalOpened = true;
            activeModalId = $(this).attr('id');

            // Tambahkan entri palsu ke history
            history.pushState({ modalOpen: true }, '');
        });
        // Saat modal ditutup
        $(document).on('hidden.bs.modal', '.modal', function () {
            modalOpened = false;
            activeModalId = null;
        });

        // Deteksi tombol back
        window.addEventListener('popstate', function (event) {
            if (modalOpened && activeModalId) {
            // Tutup modal yang sedang terbuka
            $('#' + activeModalId).modal('hide');

            // Tambahkan ulang state agar tidak keluar halaman
            history.pushState({ modalOpen: true }, '');
            }
        });

fungsi ini cukup ditaruh difooter, otomatis setiap ada modal terbuka disemua halaman, jika tombol back ditekan akan menutup modal tersebut tanpa kembali ke halaman sebelumnya.

Syaratnya:

  • Bootstrap 5.3
  • Jquery
  • modal harus punya ID

Demikian semoga bermanfaat.

Bagikan
rasupe

Recent Posts

Cara ngoding di laptop lokal, otomatis terupdate ke server.

Bismillaahirrohmaanirrohiim... Berikut ini adalah cara untuk memudahkan programmer dalam singkronisasi kode program dari laptop ke…

3 weeks ago

Setting vhost nginx untuk domain saas

Bismillaahirrohmaanirrohiim... jika kita ingin mengarahkan semua domain apapun keserver utama, dengan menangkap hostname agar menjadi…

3 weeks ago

set user dan email saat push ke github

Bismillaahirrohmaanirrohiim... Untuk push data ke github, kadangkala kita lupa untuk set user dan email, berikut…

1 month ago

Cara install mitm di windows

Bismillaahirrohmaanirrohiim... mitm adalah tools yang bisa menggantikan fiddler, untuk memantau trafik internet, dari website, aplikasi,…

1 month ago

masalah cors pada nginx method options

Bismillaahirrohmaanirrohiim... berikut ini tambahan kode pada vhost nginx untuk memperbolehkan cors method options {{settings}} location…

1 month ago

cara reset google authenticator pada cyberpanel

Bismillaahirrohmaanirrohiim... Jika kita membuka login halaman cyberpanel dan tahu tahu muncul inputan kode authenticator, berikut…

1 month ago