后台管理系统引导功能的实现

引导是软件中经常见到的一个功能,无论是在后台项目还是前台或者是移动端项目中。

那么对于引导页而言,它是如何实现的呢?通常情况下引导页是通过 聚焦 的方式,高亮一块视图,然后通过文字解释的形式来告知用户该功能的作用。

所以说对于引导页而言,它的实现其实就是:页面样式的实现。

我们只需要可以做到:

1. 高亮某一块指定的样式;

2. 在高亮的样式处通过文本展示内容;

3. 用户可以进行下一次高亮或者关闭事件;

那么就可以实现对应的引导功能。

对于引导页来说,市面上有很多现成的轮子,所以我们不需要手动的去进行以上内容的处理,我们这里可以直接使用 driver.js 进行引导页处理。

实现方案如下:

1. 安装插件

npm i driver.js@0.9.8

2. 创建组件

<template><div><el-tooltip content="引导"><svg-icon id="guide-start" icon="guide" @click="onClick" /></el-tooltip></div>
</template><script setup>
import Driver from "driver.js";
import { onMounted } from "vue";
import "driver.js/dist/driver.min.css";let driver = null;onMounted(() => {initDriver();
});const initDriver = () => {driver = new Driver({animate: true,// 禁止点击蒙版关闭allowClose: false,popoverOffset: 0,closeBtnText: "关闭",nextBtnText: "下一个",prevBtnText: "上一个",});
};// 定义导向步骤
const steps = () => {return [{element: "#guide-start",popover: {title: "引导",description: "打开引导功能",position: "bottom-right",},},{element: "#guide-hamburger",popover: {title: "汉堡按钮",description: "打开和关闭左侧菜单",},},{element: "#guide-search",popover: {title: "搜索",description: "页面链接搜索",position: "bottom-right",},},{element: "#guide-full",popover: {title: "全屏",description: "页面显示切换",position: "bottom-right",},},{element: "#guide-theme",popover: {title: "主题",description: "更换项目主题",position: "bottom-right",},},{element: "#guide-lang",popover: {title: "国际化",description: "语言切换",position: "bottom-right",},},];
};const onClick = () => {driver.defineSteps(steps());driver.start();
};
</script>

上面组件中的svg-icon标签为自定义封装的全局注册过的组件,也可以用其它图标代替,点击《Vue 3.0 中封装icon组件使用外部SVG图标》查看组件如何封装。

3. 引导高亮区域增加ID

为了导向可以按照既定的步骤执行下去,还需要给相应的元素添加对应的ID,这样在点"上一步"和"下一步"时才能精确的定位到该地方。

如下所示,这是第一步的:

这是第二步的:

后面的依次类推,绑定的ID和上面的步骤一一对应就可以了。

4. 引入组件使用

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/66386.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

nuxt3访问localstorage,sessionStorage

nuxt3在客户端的时候可以正常使用localstorage,sessionStorage&#xff0c;但是如果在服务端&#xff0c;是没有这些方法的&#xff0c;这个时候可以把数据存到cookie里&#xff0c;通过cookie来维护数据 // 访问cookie const token getCookie(token) console.log(token)// 更…

Yolov8训练方式以及C#中读取yolov8+onnx模型进行目标检测.NET 6.0

目录 首先你要定义v8的模型特征文件 下方是完整的模型编写函数 然后你要在控件窗体中定义应用这些方法以及函数 一、定义你的标签 二、下方是定义模块和坐标的方法 三、画框 完整推理函数代码块 效果展示 完整源码 训练其实和yolov10差不多 因为v10就是在v8的基础上做了优…

C 语言奇幻之旅 - 第16篇:C 语言项目实战

目录 引言1. 项目规划1.1 需求分析与设计1.1.1 项目目标1.1.2 功能需求1.1.3 技术实现方案 2. 代码实现2.1 模块化编程2.1.1 学生信息模块2.1.2 成绩管理模块 2.2 调试与测试2.2.1 调试2.2.2 测试2.2.4 测试结果 3. 项目总结3.1 代码优化与重构3.1.1 代码优化3.1.2 代码重构 3.…

YOLOv10-1.1部分代码阅读笔记-instance.py

instance.py ultralytics\utils\instance.py 目录 instance.py 1.所需的库和模块 2.def _ntuple(n): 3.class Bboxes: 4.class Instances: 1.所需的库和模块 # Ultralytics YOLO &#x1f680;, AGPL-3.0 licensefrom collections import abc from itertools import…

云安全博客阅读(二)

2024-05-30 Cloudflare acquires BastionZero to extend Zero Trust access to IT infrastructure IT 基础设施的零信任 不同于应用安全&#xff0c;基础设置的安全的防护紧急程度更高&#xff0c;基础设施的安全防护没有统一的方案IT基础设施安全的场景多样&#xff0c;如se…

06-RabbitMQ基础

目录 1.初识MQ 1.1.同步调用 1.2.异步调用 1.3.技术选型 2.RabbitMQ 2.1.安装 2.2.收发消息 2.2.1.交换机 2.2.2.队列 2.2.3.绑定关系 2.2.4.发送消息 2.3.数据隔离 2.3.1.用户管理 2.3.2.virtual host 3.SpringAMQP 3.1.导入Demo工程 3.2.快速入门 3.2.1.消…

【Linux系列】并发与顺序执行:在 Linux 脚本中的应用与选择

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

解决高并发环境消息通知涉及问题

在开发时&#xff0c;给特定用户发送消息通知是常见的场景&#xff1b;比如给1000个人每秒要发一条消息&#xff0c;如何保证时间准确性呢&#xff1f;在高并发场景下&#xff0c;确保每秒向1000个用户发送消息并保证时间准确性&#xff0c;确实是一个挑战。以下是一些解决方案…

EntityFramework Core 数据种子

在 Entity Framework Core (EF Core) 中&#xff0c;数据种子&#xff08;Seed Data&#xff09;用于在应用程序启动时向数据库表中插入一些默认数据。它通常用于为应用程序提供初始数据&#xff0c;或在开发和测试阶段填充数据库。EF Core 支持通过 模型构建器 来实现数据种子…

【机器学习篇】 科技异次元的超强 “魔杖”,开启奇幻新程

一起开启这场旅行吧&#xff0c;关注博主&#xff0c;点赞支持不迷路&#xff0c;下面一同欣赏本篇的美妙吧&#xff01;&#xff01; &#xff01; 博主主页&#xff1a; 羑悻的小杀马特.-CSDN博客 在当今科技飞速发展的时代&#xff0c;机器学习宛如一把来自科技异次元的超强…

联发科MTK6771/MT6771安卓核心板规格参数介绍

MT6771&#xff0c;也被称为Helio P60&#xff0c;是联发科技(MediaTek)推出的一款中央处理器(CPU)芯片&#xff0c;可运行 android9.0 操作系统的 4G AI 安卓智能模块。MT6771芯片采用了12纳米工艺制造&#xff0c;拥有八个ARM Cortex-A73和Cortex-A53核心&#xff0c;主频分别…

ros2笔记-2.5.3 多线程与回调函数

本节体验下多线程。 python示例 在src/demo_python_pkg/demo_python_pkg/下新建文件&#xff0c;learn_thread.py import threading import requestsclass Download:def download(self,url,callback):print(f线程&#xff1a;{threading.get_ident()} 开始下载&#xff1a;{…

人工智能的发展领域之GPU加速计算的应用概述、架构介绍与教学过程

文章目录 一、架构介绍GPU算力平台概述优势与特点 二、注册与登录账号注册流程GPU服务器类型配置选择指南内存和存储容量网络带宽CPU配置 三、创建实例实例创建步骤镜像选择与设置 四、连接实例SSH连接方法远程桌面配置 一、架构介绍 GPU算力平台概述 一个专注于GPU加速计算的…

肘部法则确定聚类数

肘部法则&#xff08;Elbow Method&#xff09;是一种常用于确定聚类数的技术。其基本思想是通过计算不同聚类数下的聚类质量&#xff08;通常使用每个数据点到其聚类中心的距离的平方和&#xff0c;即SSE&#xff0c;Sum of Squared Errors&#xff09;&#xff0c;并寻找“肘…

WebClient

一、WebClient 概述 1.1 什么是 WebClient WebClient 是 Spring 5 引入的一个 基于响应式编程模型 的 HTTP 客户端。与传统的 RestTemplate 相比&#xff0c;WebClient 采用了 Reactor 库&#xff0c;支持 非阻塞式&#xff08;异步&#xff09;调用&#xff0c;可充分利用多…

Unity【Colliders碰撞器】和【Rigibody刚体】的应用——小球反弹效果

目录 Collider 2D 定义&#xff1a; 类型&#xff1a; Rigidbody 2D 定义&#xff1a; 属性和行为&#xff1a; 运动控制&#xff1a; 碰撞检测&#xff1a; 结合使用 实用检测 延伸拓展 1、在Unity中优化Collider 2D和Rigidbody 2D的性能 2、Unity中Collider 2D…

[微服务]redis主从集群搭建与优化

搭建主从集群 单节点Redis的并发能力是有上限的&#xff0c;要进一步提高Redis的并发能力&#xff0c;就需要搭建主从集群&#xff0c;实现读写分离。 1. 主从集群结构 下图就是一个简单的Redis主从集群结构&#xff1a; 如图所示&#xff0c;集群中有一个master节点、两个s…

自动化立体仓库堆垛机SRM控制系统自动控制功能块开发

1、堆垛机SRM控制系统硬件组态如下图 2、堆垛机SRM控制系统HMI屏幕页面如下图 驱动状态显示、堆垛机状态 3、堆垛机SRM控制系统中相关变量定义如下图 其中包含系统控制相关变量:系统急停、系统手动、复位、货叉左极限、货叉左居中 货叉右极限 货叉右居中 货叉编码器位置反…

【数据结构】栈与队列(FIFO)

在阅读该篇文章之前&#xff0c;可以先了解一下堆栈寄存器和栈帧的运作原理&#xff1a;<【操作系统】堆栈寄存器sp详解以及栈帧>。 栈(FILO) 特性: 栈区的存储遵循着先进后出的原则。 例子: 枪的弹夹&#xff0c;最先装进去的子弹最后射出来&#xff0c;最后装入的子弹…

黑马JavaWeb开发跟学(十五).Maven高级

黑马JavaWeb开发跟学.十五.Maven高级 Maven高级1. 分模块设计与开发1.1 介绍1.2 实践1.2.1 分析1.2.2 实现 1.3 总结 2. 继承与聚合2.1 继承2.1.1 继承关系2.1.1.1 思路分析2.1.1.2 实现 2.1.2 版本锁定2.1.2.1 场景2.1.2.2 介绍2.1.2.3 实现2.1.2.4 属性配置 2.2 聚合2.2.1 介…