您可以按照您想要的任何方式设置消息样式,我将像往常一样使用“Glassmorphism”并添加一些颜色。

.alert-success {    background: rgba( 114, 255, 136, 0.45 );    box-shadow: 0 8px 32px 0 rgba( 31, 38, 135, 0.37 );    backdrop-filter: blur( 10px );    -webkit-backdrop-filter: blur( 10px );    border-radius: 10px;    border: 1px solid rgba( 255, 255, 255, 0.18 );}

最后一步,我们需要创建消息容器并将该容器添加到 app.vue 文件中。

通知容器将简单地呈现存储在基本文件中的列表的数组。

不要忘记将“通知容器”添加到主 app.vue 文件中。

就是这样,我们可以重新启动我们的开发服务器并触发几次通知消息,只是为了检查结果。
\\\"Nuxt
通过模式和通知的集成,我们的 Nuxt.js 电子商务应用程序变得更加动态、交互和用户友好。这些元素有助于增强购物体验,使我们的客户能够预览产品并在整个旅程中随时了解情况。

随着我们不断构建和改进我们的电子商务平台,我们可以进一步扩展模式和通知的功能,根据特定用例进行定制,并确保为我们的用户提供无缝且引人入胜的体验。

如果您需要本教程的源代码,可以在此处获取。

","image":"http://www.luping.net","datePublished":"2024-07-31T23:20:03+08:00","dateModified":"2024-07-31T23:20:03+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 為 Nuxt.js 電子商務平台設計響應式模態與使用者通知

為 Nuxt.js 電子商務平台設計響應式模態與使用者通知

發佈於2024-07-31
瀏覽:329

Designing Responsive Modals and User Notifications for Nuxt.js E-commerce Platform

在我的网络笔记中查看这篇文章!

在上一篇文章中,我们完成了电子商务商店主页的创建,现在是时候进一步添加一些动态元素,例如模式和通知。首先,模态窗口对于产品快速查看、产品管理等很有用,而通知作用至关重要,因为它是与用户沟通的最佳方式,从欢迎消息开始到销售消息结束。是的,正如您从介绍和标题中看到的那样,我们今天的文章将包含以下内容:

  1. 在 Nuxt.js 中创建自定义模态框
  2. 在我们的电子商务商店中配置通知消息

现在我们知道模式和警报有多重要,让我们研究如何将它们集成到我们的 Nuxt.js 电子商务应用程序中并了解实施细节。

1. 在 Nuxt.js 中创建自定义模态框

我们需要澄清,我们想要创建一个可重用的模态窗口,以便它可以以多种方式使用并显示不同的数据。为此,我们将创建一个主模态组件,其中包含特定于模态的样式和项目,这些样式和项目可以在我们的模态组件内呈现。

首先,在“ui”文件夹中创建一个 Modal.vue 文件,其中包含一个模糊背景的容器和一个包含动态渲染项目的模态 div。另外,我们将导入“xmark”图标并将其设为关闭模态窗口的按钮。


在我们的基础存储中,我们将添加两个带有 false 值的新变量“modalStatus”和字符串形式的“modalType”,并添加将修改这些值的简单操作。

aSetModalStatus(status) {
    this.modalStatus = status;
},
aSetModalType(type) {
    this.modalType = type;
},

状态变量将控制模态渲染行为,类型将更新不同的模态类型。

现在,当我们有了模态控制系统时,我们可以将模态组件添加到默认布局中。不要忘记导入我们的基础商店。


太好了,我们的可重用模态组件已准备就绪,现在如果我们想显示模态,我们只需更新基础存储中的 modalStatus 值即可。

此外,您可以向模态组件添加任何您想要的样式,但我建议您使用“Glassmorphism”,它会看起来很时尚。

.container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 100;
    display: flex;
    justify-content: center;
    align-items: center;
    .modal {
        min-width: 300px;
        min-height: 300px;
        background: rgba( 255, 255, 255, 0.9 );
        box-shadow: 0 8px 32px 0 rgba( 31, 38, 135, 0.37 );
        backdrop-filter: blur( 13px );
        -webkit-backdrop-filter: blur( 13px );
        border-radius: 10px;
        border: 1px solid rgba( 255, 255, 255, 0.18 );
        padding: 24px;
        display: flex;
        flex-direction: column;
        &__close {
            display: flex;
            justify-content: flex-end;
            width: 100%;
            &--btn {
                border: none;
                background-color: transparent;
                cursor: pointer;
                outline: none;
                display: flex;
                align-items: center;
            }
            &--icon {
                color: #6c757d;
                font-size: 20px;
            }
        }
    }
}

我们在这里做得很好,但我建议您继续并创建将使用我们的模式的第一个组件 - “产品预览”,该组件将在单击任何产品卡上的预览按钮后可用。让我们在“common”文件夹中创建一个新的 Vue 文件并添加一些 HTML/CSS 元素:


然后将此组件导入到Modal.vue文件中,并将其插入到内容div中。


现在,我们只需要在卡片中添加一个像“showPreview”这样的函数,这样用户点击后,该函数就会将模态类型设置为“product-preview”,并将模态状态设置为“true”。就是这样,我们有了可重用的模式和产品预览功能。
modal result
好的,我们需要继续并向 Nuxt.js 项目添加警报消息。

2. 在我们的电子商务商店中配置通知消息

好吧,我们可以添加诸如模式改变其样式之类的东西,并将其称为警报,听起来是一个简单而快速的解决方案。但是,如果同时触发两个或多个警报(例如“欢迎”消息和“您的愿望清单不为空”消息)怎么办?为了解决这个问题,我们将创建一个警报容器,该容器将根据传入消息的数量进行扩展。

首先,我们将向商店添加警报设置,类似于我们对模态部分所做的操作。将“notificationsList”数组添加到状态部分,并添加将从列表中推送和删除通知的通知操作。每个通知都有一个唯一的 ID,并显示状态、类型、消息和延迟(我们的消息可见的时间量)。

aSetNotification(payload) {
    const notification = {
        id: uuidv4(),
        show: true,
        type: payload.type,
        msg: payload.msg,
        delay: payload.delay ? payload.delay : 7000,
    }
    this.notificationsList.push(notification);
},
aRemoveNotification(id) {
    const indexToRemove = this.notificationsList.findIndex((element) => element.id === id);
    if (indexToRemove !== -1) {
        this.notificationsList.splice(indexToRemove, 1);
    }
},

下一步,我们需要创建一个“通知”组件,该组件将根据消息类型自行呈现消息。另外,我们需要使用延迟时间并自动删除消息。




您可以按照您想要的任何方式设置消息样式,我将像往常一样使用“Glassmorphism”并添加一些颜色。

.alert-success {
    background: rgba( 114, 255, 136, 0.45 );
    box-shadow: 0 8px 32px 0 rgba( 31, 38, 135, 0.37 );
    backdrop-filter: blur( 10px );
    -webkit-backdrop-filter: blur( 10px );
    border-radius: 10px;
    border: 1px solid rgba( 255, 255, 255, 0.18 );
}

最后一步,我们需要创建消息容器并将该容器添加到 app.vue 文件中。

通知容器将简单地呈现存储在基本文件中的列表的数组。




不要忘记将“通知容器”添加到主 app.vue 文件中。


就是这样,我们可以重新启动我们的开发服务器并触发几次通知消息,只是为了检查结果。
Nuxt js alert result
通过模式和通知的集成,我们的 Nuxt.js 电子商务应用程序变得更加动态、交互和用户友好。这些元素有助于增强购物体验,使我们的客户能够预览产品并在整个旅程中随时了解情况。

随着我们不断构建和改进我们的电子商务平台,我们可以进一步扩展模式和通知的功能,根据特定用例进行定制,并确保为我们的用户提供无缝且引人入胜的体验。

如果您需要本教程的源代码,可以在此处获取。

版本聲明 本文轉載於:https://dev.to/webcraft-notes/designing-responsive-modals-and-user-notifications-for-nuxtjs-e-commerce-platform-1gn2?1如有侵犯,請聯絡study_golang@163 .com刪除
最新教學 更多>
  • 如何使用不同數量列的聯合數據庫表?
    如何使用不同數量列的聯合數據庫表?
    合併列數不同的表 當嘗試合併列數不同的數據庫表時,可能會遇到挑戰。一種直接的方法是在列數較少的表中,為缺失的列追加空值。 例如,考慮兩個表,表 A 和表 B,其中表 A 的列數多於表 B。為了合併這些表,同時處理表 B 中缺失的列,請按照以下步驟操作: 確定表 B 中缺失的列,並將它們添加到表的...
    程式設計 發佈於2025-02-06
  • 如何防止在HTML元素上拖放?
    如何防止在HTML元素上拖放?
    如何在Web設計中禁用拖放在網絡設計中,對於控制用戶與某些HTML的交互是至關重要的元素。一個普遍的挑戰是在不可能期望的情況下防止瀏覽器啟動拖放操作。 暫時禁用拖放功能,您可以使用以下方法: 通過在這些事件處理程序中返回false,您可以有效防止瀏覽器啟動拖放操作。這樣可以確保用戶的預期操作(例如...
    程式設計 發佈於2025-02-06
  • 大批
    大批
    [2 數組是對象,因此它們在JS中也具有方法。 切片(開始):在新數組中提取部分數組,而無需突變原始數組。 令arr = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    程式設計 發佈於2025-02-06
  • 如何從PHP服務器發送文件?
    如何從PHP服務器發送文件?
    將文件發送到user
    程式設計 發佈於2025-02-06
  • 可以在純CS中將多個粘性元素彼此堆疊在一起嗎?
    可以在純CS中將多個粘性元素彼此堆疊在一起嗎?
    </main> <section> ,但无法使其正常工作,如您所见。任何洞察力都将不胜感激! display:grid; { position:sticky; top:1em; z-index:1 1 ; { { { pos...
    程式設計 發佈於2025-02-06
  • 如何限制動態大小的父元素中元素的滾動範圍?
    如何限制動態大小的父元素中元素的滾動範圍?
    在交互式界面中實現垂直滾動元素的CSS高度限制 考慮一個佈局,其中我們具有與可滾動的映射div一起移動的subollable map div用戶的垂直滾動,同時保持其與固定側邊欄的對齊方式。但是,地圖的滾動無限期擴展,超過了視口的高度,阻止用戶訪問頁面頁腳。 可以限制地圖的滾動,我們可以利用CS...
    程式設計 發佈於2025-02-06
  • 如何使用固定的標頭和可滾動車身創建Bootstrap 3表?
    如何使用固定的標頭和可滾動車身創建Bootstrap 3表?
    用粘性定位一個簡單但有效的解決方案涉及使用CSS粘性定位。這種方法涉及分配位置:粘性;頂部:0;到表標頭(TH)元素,以確保它們保持固定在表的頂部。這是實現的分解:在上面的代碼中,我們使用class tablefixhead創建一個容器,其中包括溢出:auto;使表可滾動和100px的高度定義可...
    程式設計 發佈於2025-02-06
  • 如何在整個HTML文檔中設計特定元素類型的第一個實例?
    如何在整個HTML文檔中設計特定元素類型的第一個實例?
    [2單獨使用CSS,整個HTML文檔可能是一個挑戰。 the:第一型偽級僅限於與其父元素中類型的第一個元素匹配。 以下CSS將使用添加的類樣式的第一個段落: }
    程式設計 發佈於2025-02-06
  • 如何在SQL中的單個字段中有效搜索多個值?
    如何在SQL中的單個字段中有效搜索多個值?
    [2進入其組成部分,並單獨搜索每個部分。當處理以空格分離的搜索詞時,這一點特別有用。 在SQL中實現此目標,人們可能會考慮使用與通配符的類似運算符在每個搜索詞之前和之後匹配任何字符。但是,這種方法不是很有效,因為它需要多個類似的子句,並且可能導致性能問題。 相反,一個更有效的解決方案是使用在運算符中...
    程式設計 發佈於2025-02-06
  • 如何使用$ _GET在PHP中檢索多個選擇框值?
    如何使用$ _GET在PHP中檢索多個選擇框值?
    在php array。 解決方案:作為選項數組,您需要將方括號添加到Select元素的名稱中。這是您的代碼的修改版本:”多個...> 此更改使PHP能夠將所選選項解釋為數組。然後,您可以使用以下代碼在PHP腳本中訪問它: Header(“ content-type:text/plain”); f...
    程式設計 發佈於2025-02-06
  • 為什麼在Chrome中縮放孩子Div的父級為“溢出:隱藏”和“ border-radius”的父級?
    為什麼在Chrome中縮放孩子Div的父級為“溢出:隱藏”和“ border-radius”的父級?
    transform:scale and溢出:chrome 在使用CSS3 Transform:Scale:Scale,一個特殊問題時。如果父級div溢出:應用和邊界劃線了,則縮放子div會導致其超越其父。 CSS過渡將解決該問題。但是,這種方法被證明是無效的。 的解決方案的解決方案很大: T...
    程式設計 發佈於2025-02-06
  • 如何從Python中的字符串中刪除表情符號:固定常見錯誤的初學者指南?
    如何從Python中的字符串中刪除表情符號:固定常見錯誤的初學者指南?
    從python 導入編解碼器 導入 text = codecs.decode('這狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#帶有表情符號 emoji_pattern = re.compile(“ [”...
    程式設計 發佈於2025-02-06
  • 為什麼我會收到MySQL錯誤#1089:錯誤的前綴密鑰?
    為什麼我會收到MySQL錯誤#1089:錯誤的前綴密鑰?
    mySQL錯誤#1089:錯誤的前綴鍵錯誤descript 理解prefix keys primary鍵(movie_id(3))primary鍵(Movie_id) primary鍵(Movie_id) primary鍵(Movie_id) > `這將在整個Movie_ID列上建立標...
    程式設計 發佈於2025-02-06
  • 如何為PostgreSQL中的每個唯一標識符有效地檢索最後一行?
    如何為PostgreSQL中的每個唯一標識符有效地檢索最後一行?
    [2最後一行與數據集中的每個不同標識符關聯。考慮以下數據: 1 2014-02-01 kjkj 1 2014-03-11 ajskj 3 2014-02-01 sfdg 3 2014-06-12 fdsa 在(ID)上選擇DISTINC 來自the_table 按ID訂單,date desc;...
    程式設計 發佈於2025-02-06
  • 從GO切片開始時刪除元素如何影響其容量?
    從GO切片開始時刪除元素如何影響其容量?
    理解slice容量在使用GO GO slice結構數組:指向下面的數組備份slice。 len:slice中的元素數。表示它可以保留的元素數量。 ,我們創建了一個新切片,該切片與原始陣列相同。但是,新切片的長度減小,而容量保持不變。這是因為基礎數組具有足夠的能力來容納其餘元素。 在另一方面...
    程式設計 發佈於2025-02-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3