您可以按照您想要的任何方式设置消息样式,我将像往常一样使用“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
浏览:552

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如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何使用不同数量列的联合数据库表?
    如何使用不同数量列的联合数据库表?
    合并列数不同的表 当尝试合并列数不同的数据库表时,可能会遇到挑战。一种直接的方法是在列数较少的表中,为缺失的列追加空值。 例如,考虑两个表,表 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用户的垂直滚动,同时保持其与固定侧边栏的对齐方式。但是,地图的滚动无限期扩展,超过了视口的高度,阻止用户访问页面页脚。 可以限制地图的滚动,我们可以利用CSS...
    编程 发布于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”); fo...
    编程 发布于2025-02-06
  • 为什么在Chrome中缩放孩子Div的父级为“溢出:隐藏”和“ border-radius”的父级?
    为什么在Chrome中缩放孩子Div的父级为“溢出:隐藏”和“ border-radius”的父级?
    transform:scale and溢出:chrome 在使用CSS3 Transform:Scale:Scale,一个特殊问题时。如果父级div溢出:应用和边界划线了,则缩放子div会导致其超越其父。 CSS过渡将解决该问题。但是,这种方法被证明是无效的。的解决方案的解决方案很大: Thi...
    编程 发布于2025-02-06
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python 导入编解码器 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有表情符号 emoji_pattern = re.compile(“ [”...
    编程 发布于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
  • 如何在Java列表中有效计算元素的发生?
    如何在Java列表中有效计算元素的发生?
    计数列表中的元素出现在列表 中,在java编程中,列举列表中列举元素出现的任务来自列表。为此,收集框架提供了全面的工具套件。在这种情况下,Batocurrences变量将保持值3,代表动物列表中的“ BAT”出现的数量。 &&& [此方法是简单的,可以得出准确的结果,使其成为计算列表中元素出现的理...
    编程 发布于2025-02-06

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3