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

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

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

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

我们只需要可以做到:

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

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

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

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

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

实现方案如下:

1. 安装插件

javascript 复制代码
npm i [email protected]

2. 创建组件

html 复制代码
<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. 引入组件使用

相关推荐
森哥的歌4 天前
SVG 知识详解:从入门到精通
svg·数据可视化·前端开发·矢量图形·web图形
森哥的歌4 天前
CSS3实现磨砂玻璃效果:从原理到实战应用
css3·前端开发·ui设计·磨砂玻璃效果·web设计
森哥的歌7 天前
CSS Layer 详解
css·css3·web开发·前端开发·样式表
破烂公司一级特派员8 天前
前端开发实战:用React Hooks优化你的组件性能
性能优化·实战·react·前端开发·hooks
kidding7231 个月前
微信小程序怎么分包步骤(包括怎么主包跳转到分包)
前端·微信小程序·前端开发·分包·wx.navigateto·subpackages
~央千澈~1 个月前
剖析AI与5G:是夸大其词,还是时代变革的引擎?-优雅草卓伊凡
物联网·5g·前端开发
知识分享小能手2 个月前
CSS3学习教程,从入门到精通,CSS3 弹性盒子(Flexbox)布局全面指南(20)
前端·javascript·css·学习·css3·html5·前端开发
aiguangyuan2 个月前
第六篇:Setup:组件渲染前的初始化过程是怎样的?
javascript·vue·前端开发
Pro_er2 个月前
Vue3生命周期钩子函数深度解析:从源码到实战的万字指南
vue·前端开发
Pro_er2 个月前
Vue3组合式API终极指南:从原理到实战,彻底掌握高效开发!
vue·前端开发