首頁 > web前端 > css教學 > 在登入彈出視窗中新增「搖晃」效果以提供視覺錯誤提示

在登入彈出視窗中新增「搖晃」效果以提供視覺錯誤提示

Mary-Kate Olsen
發布: 2024-11-28 11:11:14
原創
744 人瀏覽過

Adding a

有時,微妙的設計元素可以對使用者體驗產生巨大的影響。登入彈出視窗上的「搖晃」效果不是顯示傳統的錯誤訊息,而是提供了明確且立即的指示,表明出現了問題。本教學將指導您使用 vanilla JavaScriptCSS 動畫 和開源程式庫 Tippy.js.

來實現此功能。

我們的目標是:

  1. 使用 Tippy.js 建立登入彈出視窗。
  2. 加入錯誤發生時的「搖晃」效果。
  3. 搖晃結束後自動重置動畫。

讓我們開始吧!


第 1 部分:使用 CSS 設定搖動動畫

我們先為搖動效果定義一個可重複使用的 CSS 動畫。下面的 @keyframes 規則模仿左右搖晃:

@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;
}

登入後複製
  • 關鍵影格詳細資料 :translate3d 屬性將彈出框稍微向左和向右移動以創造晃動效果。
  • 可重複使用類別:將 shake 類別套用至任何元素都會觸發動畫。

第 2 部分:使用 Tippy.js 建立登入彈出窗口

我們將使用 Tippy.js 建立一個可點擊的登入彈出視窗。彈出視窗將包括:

  • 電子郵件輸入欄位。
  • 「登入」按鈕。
  • 用於處理登入邏輯和搖晃效果的事件偵聽器。

這是設定彈出視窗的核心 JavaScript:

第 1 步:登入類

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);
    });

登入後複製

彈出框的 CSS :確保彈出框符合您的設計。這是一個簡單的設定:

.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;
}

登入後複製

HTML 觸發器元素 :在 HTML 中加入觸發器元素:





<hr>

<h3>
  
  
  第四部分:測試震動效果
</h3>

<ol>
<li>點選<strong>登入</strong>按鈕開啟彈出視窗。 </li>
<li>輸入無效的電子郵件並提交。觀察彈出框晃動,表示有錯誤。 </li>
<li>輸入有效的電子郵件,看不到晃動-成功! </li>
</ol>


<hr>

<h3>
  
  
  結論:使用者友善的錯誤提示
</h3>

<p>搖動效果透過提供清晰、直覺的錯誤指示器來增強使用者體驗,而不會因為額外的訊息而使 UI 變得混亂。與用於時尚彈出視窗的 Tippy.js 和用於互動性的 vanilla JS 相結合,此設定乾淨、實用且具有視覺吸引力。 </p>

<p>不斷嘗試和調整-因為出色的使用者體驗取決於細節! </p>

<p>有關 Web 開發的更多技巧,請查看 <strong>DailySandbox</strong> 並註冊我們的<strong>免費時事通訊</strong>以保持領先地位! </p>


          

            
        
登入後複製

以上是在登入彈出視窗中新增「搖晃」效果以提供視覺錯誤提示的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:dev.to
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板