Rumah hujung hadapan web tutorial css Menambah Kesan \'Gegar\' pada Popover Log Masuk untuk Petunjuk Ralat Visual

Menambah Kesan \'Gegar\' pada Popover Log Masuk untuk Petunjuk Ralat Visual

Nov 28, 2024 am 11:11 AM

Adding a

Kadangkala, elemen reka bentuk yang halus boleh membuat perbezaan besar dalam pengalaman pengguna. Daripada memaparkan mesej ralat tradisional, kesan "gegar" pada popup log masuk memberikan petunjuk yang jelas dan segera bahawa sesuatu telah berlaku. Tutorial ini akan membimbing anda untuk melaksanakan fungsi ini menggunakan vanila JavaScript , animasi CSS dan pustaka sumber terbuka Tippy.js.

Objektif kami adalah untuk:

  1. Buat popover log masuk dengan Tippy.js.
  2. Tambahkan kesan "gegaran" apabila ralat berlaku.
  3. Tetapkan semula animasi secara automatik sebaik sahaja gegaran tamat.

Jom selami!


Bahagian 1: Menyediakan Animasi Gegar dengan CSS

Kita akan mulakan dengan mentakrifkan animasi CSS boleh guna semula untuk kesan gegaran. Peraturan @keyframes di bawah meniru goncangan sebelah ke sisi:

@keyframes shaking {
    10%, 90% { transform: translate3d(-1px, 0, 0); }
    20%, 80% { transform: translate3d(2px, 0, 0); }
    30%, 50%, 70% { transform: translate3d(-4px, 0, 0); }
    40%, 60% { transform: translate3d(4px, 0, 0); }
}
.shake {
    animation: shaking 0.82s cubic-bezier(.36,.07,.19,.97) both;
}

Salin selepas log masuk
  • Butiran Kerangka Kunci : Sifat translate3d menggerakkan popover sedikit ke kiri dan kanan untuk mencipta kesan gegaran.
  • Kelas Boleh Digunakan Semula : Menggunakan kelas goncang pada mana-mana elemen akan mencetuskan animasi.

Bahagian 2: Mencipta Popover Log Masuk dengan Tippy.js

Kami akan menggunakan Tippy.js untuk membuat popover log masuk boleh klik. Popover akan merangkumi:

  • Medan input e-mel.
  • Butang "Log Masuk".
  • Pendengar acara untuk mengendalikan logik log masuk dan kesan gegaran.

Berikut ialah JavaScript teras untuk menyediakan popover:

Langkah 1: Kelas Log Masuk

APP.Signin = class {
    constructor($target) {
        this.values = {}; // Store any required state
        if ($target) this.$target = $target; // The DOM element triggering the popover
        this.init(); // Initialize the popover
        return this;
    }

    // Trigger the shake animation
    shake() {
        this.$tippy.classList.add('shake');
        return this;
    }

    // Handle Sign-In button clicks
    onSigninClicked(event) {
        event.preventDefault();

        // Retrieve the entered email
        let email = document.querySelector('.app-signin-email').value;

        // Error and success handlers
        let _onError = () => this.shake();
        let _onSuccess = (response) => {
            if (response.errors.length) {
                this.shake(); // Shake on error
            } else {
                // Handle successful login
                console.log('Login successful!');
            }
        };

        // Simulate a backend login request
        let form_data = new FormData();
        form_data.append('method', 'quickSignIn');
        form_data.append('email', email);

        axios({
            method: 'POST',
            url: 'path/to/server',
            data: form_data,
            headers: { 'content-type': 'application/x-www-form-urlencoded;charset=UTF-8' },
        })
            .then((response) => (typeof response.data === 'string' ? JSON.parse(response.data) : response.data))
            .then(_onSuccess)
            .catch(_onError);
    }

    // Define the HTML content of the popover
    getContent() {
        return `
            <div>




<hr>

<p><strong>2228+ FREE</strong> <u><b><strong>RESOURCES</strong></b></u> <strong>FOR DEVELOPERS!! ❤️</strong> ?? <strong><sub><strong>(updated daily)</strong></sub></strong></p>

<blockquote>
<p>1400+ Free HTML Templates<br><br>
359+ Free News Articles<br><br>
69+ Free AI Prompts<br><br>
323+ Free Code Libraries<br><br>
52+ Free Code Snippets & Boilerplates for Node, Nuxt, Vue, and more!<br><br>
25+ Free Open Source Icon Libraries</p>
</blockquote>

<p>Visit dailysandbox.pro for free access to a treasure trove of resources!</p>


<hr>

<h3>
  
  
  Part 3: Wiring It All Together
</h3>

<p><strong>Simulated Backend</strong> : If you don’t have a real server, mock responses with a promise:<br>
</p>

<pre class="brush:php;toolbar:false">const mockServer = (email) =>
    new Promise((resolve, reject) => {
        setTimeout(() => {
            if (email === 'test@email.com') resolve({ errors: [] });
            else reject({ errors: ['Invalid email'] });
        }, 500);
    });

Salin selepas log masuk

CSS untuk Popover : Pastikan popover sepadan dengan reka bentuk anda. Berikut ialah persediaan mudah:

.app-signin {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.app-signin-email {
    width: 100%;
    padding: 10px;
    font-size: 1rem;
    border: 1px solid #ccc;
    border-radius: 4px;
}

.app-signin-btn {
    background-color: #007bff;
    color: white;
    text-align: center;
    padding: 10px;
    border-radius: 4px;
    cursor: pointer;
}

.app-signin-btn:hover {
    background-color: #0056b3;
}

Salin selepas log masuk

Elemen Pencetus HTML : Tambahkan elemen pencetus pada HTML anda:

butang<




<hr>

<h3>
  
  
  Bahagian 4: Uji Kesan Gegaran
</h3>

<ol>
<li>Klik butang <strong>Log Masuk</strong> untuk membuka popover.</li>
<li>Masukkan e-mel yang tidak sah dan serahkan. Tonton gegaran popover, menunjukkan ralat.</li>
<li>Masukkan e-mel yang sah dan lihat tiada gegaran—berjaya!</li>
</ol>


<hr>

<h3>
  
  
  Kesimpulan: Petunjuk Ralat Mesra Pengguna
</h3>

<p>Kesan gegaran meningkatkan pengalaman pengguna dengan menawarkan penunjuk ralat yang jelas dan intuitif tanpa mengacaukan UI dengan mesej tambahan. Digabungkan dengan Tippy.js untuk popover anggun dan JS vanila untuk interaktiviti, persediaan ini bersih, berfungsi dan menarik secara visual.</p>

<p>Teruskan percubaan dan ubah suai—kerana UX yang hebat adalah mengenai butirannya!</p>

<p>Untuk mendapatkan lebih banyak petua tentang pembangunan web, lihat <strong>DailySandbox</strong> dan daftar untuk <strong>surat berita percuma</strong> kami untuk kekal di hadapan!</p>


          

            
        
Salin selepas log masuk

Atas ialah kandungan terperinci Menambah Kesan \'Gegar\' pada Popover Log Masuk untuk Petunjuk Ralat Visual. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Vue 3 Vue 3 Apr 02, 2025 pm 06:32 PM

Ia &#039; s! Tahniah kepada pasukan Vue untuk menyelesaikannya, saya tahu ia adalah usaha besar dan lama datang. Semua dokumen baru juga.

Sedikit di CI/CD Sedikit di CI/CD Apr 02, 2025 pm 06:21 PM

Saya &#039;

Bolehkah anda mendapatkan nilai harta CSS yang sah dari penyemak imbas? Bolehkah anda mendapatkan nilai harta CSS yang sah dari penyemak imbas? Apr 02, 2025 pm 06:17 PM

Saya mempunyai seseorang yang menulis dengan soalan yang sangat legit ini. Lea hanya blog tentang bagaimana anda boleh mendapatkan sifat CSS yang sah dari penyemak imbas. That &#039; s seperti ini.

Menggunakan Markdown dan Penyetempatan di Editor Blok WordPress Menggunakan Markdown dan Penyetempatan di Editor Blok WordPress Apr 02, 2025 am 04:27 AM

Jika kita perlu menunjukkan dokumentasi kepada pengguna secara langsung dalam editor WordPress, apakah cara terbaik untuk melakukannya?

Kad yang disusun dengan kedudukan melekit dan sasaran sass Kad yang disusun dengan kedudukan melekit dan sasaran sass Apr 03, 2025 am 10:30 AM

Pada hari yang lain, saya melihat sedikit ini sangat indah dari laman web Corey Ginnivan di mana koleksi kad timbunan di atas satu sama lain semasa anda menatal.

Membandingkan penyemak imbas untuk reka bentuk responsif Membandingkan penyemak imbas untuk reka bentuk responsif Apr 02, 2025 pm 06:25 PM

Terdapat beberapa aplikasi desktop ini di mana matlamat menunjukkan laman web anda pada dimensi yang berbeza pada masa yang sama. Oleh itu, anda boleh menulis

Cara menggunakan grid CSS untuk tajuk dan kaki melekit Cara menggunakan grid CSS untuk tajuk dan kaki melekit Apr 02, 2025 pm 06:29 PM

CSS Grid adalah koleksi sifat yang direka untuk menjadikan susun atur lebih mudah daripada yang pernah berlaku. Seperti apa -apa, ada sedikit keluk pembelajaran, tetapi grid adalah

Fon Font Google Fon Fon Font Google Fon Apr 09, 2025 am 10:42 AM

Saya melihat Font Google melancarkan reka bentuk baru (tweet). Berbanding dengan reka bentuk besar yang terakhir, ini terasa lebih berulang. Saya hampir tidak dapat memberitahu perbezaannya

See all articles