实操:driver.js 实现产品导览、亮点、上下文帮助

官网

https://driverjs.com/

依赖

<script src="https://cdn.jsdelivr.net/npm/driver.js@1.0.1/dist/driver.js.iife.js"></script>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/driver.js@1.0.1/dist/driver.css"/>

配置

注意:获取实例是:``window.driver.js.driver`

    <script>
        const driver = window.driver.js.driver;
        function helpMe() {
            const driverObj = driver({
                // 开启动画
                animate: true,
                // 开启进度
                showProgress: true,
                showButtons: ['next', 'previous', 'close'],
                prevBtnText: '上一步',
                nextBtnText: '下一步',
                doneBtnText: '结束引导',
                popoverClass: 'driverjs-theme',
                allowClose: true,
                // 是否自动滚动以使高亮元素可见
                scrollIntoViewOptions: {
                    behavior: 'smooth',
                    block: 'center'
                },
                steps: [
                    {
                        element: '#index',
                        popover: {
                            title: '这是首页',
                        }
                    },
                    {
                        element: '#torental',
                        popover: {
                            title: '租车点这里',
                            description: '你可以xxxxxxxxxxx'
                        }
                    }
                    ,
                    {
                        element: '#steps',
                        popover: {
                            title: '租车流程看这里',
                            description: '你可以xxxxxxxxxxx'
                        }
                    }
                ]
            });
            driverObj.drive();
        }
    </script>

效果

GIF 2024-4-3 18-49-24

其他用法

也可以使用它来显示一个简单的模态,而不突出显示任何元素。

const driverObj = driver();

driverObj.highlight({
  popover: {
    description: "<img src='https://i.imgur.com/EAQhHu5.gif' style='height: 202.5px; width: 270px;' /><span style='font-size: 15px; display: block; margin-top: 10px; text-align: center;'>Yet another highlight example.</span>",
  }
})

GIF 2024-4-3 18-45-51

附录

案例完整code

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.w3.org/1999/xhtml" xmlns:sa="http://www.thymeleaf.org/extras/sa-token">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>汽车租赁系统</title>
    <!-- Bootstrap CSS -->
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="stylesheet">
    <link href="/css/my.css" rel="stylesheet">
    <script src="https://cdn.jsdelivr.net/npm/driver.js@1.0.1/dist/driver.js.iife.js"></script>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/driver.js@1.0.1/dist/driver.css" />
    <style>
        /* Custom Styles */
        body {
            padding-top: 70px;
            padding-bottom: 50px;
            background-color: #f8f9fa;
            /* 设置页面背景色 */
            color: #343a40;
            /* 设置文本颜色 */
        }

        .footer {
            position: fixed;
            bottom: 0;
            width: 100%;
        }

        .hero {
            background-color: #007bff;
            /* 设置hero区域背景色 */
            color: #fff;
            /* 设置hero区域文本颜色 */
        }

        .about {
            background-color: #f8f9fa;
            /* 设置about区域背景色 */
        }

        .renting-process {
            background-color: #fff;
            /* 设置租车流程区域背景色 */
        }

        .renting-process .card {
            border: none;
            /* 移除卡片边框 */
            background-color: #f8f9fa;
            /* 设置卡片背景色 */
        }

        .renting-process .card-title {
            color: #007bff;
            /* 设置卡片标题颜色 */
        }
    </style>
</head>

<body>

    <!-- Navigation Bar -->
    <nav class="navbar navbar-expand-lg navbar-light bg-light fixed-top" th:fragment="navbar">
        <div class="container">
            <a class="navbar-brand" href="/">租车行者</a>
            <button class="navbar-toggler" type="button" data-bs-toggle="collapse"
                data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false"
                aria-label="Toggle navigation">
                <span class="navbar-toggler-icon"></span>
            </button>
            <div class="collapse navbar-collapse" id="navbarSupportedContent">
                <ul class="navbar-nav ms-auto mb-2 mb-lg-0">
                    <li class="nav-item">
                        <a class="nav-link" href="/" id="index">首页</a>
                    </li>
                    <li class="nav-item">
                        <a class="nav-link" href="/car/list" id="torental">车辆租赁</a>
                    </li>

                    <li class="nav-item">
                        <a class="nav-link" href="/like/carList">我的收藏</a>
                    </li>
                    <li class="nav-item">
                        <a class="btn btn-outline-primary" href="/login" sa:notLogin>注册/登录</a>
                    </li>
                    <li class="nav-item">
                        <a class="btn btn-outline-success"  onclick="helpMe()">帮助引导</a>
                    </li>
                    <li class="nav-item" sa:login>
                        <a class="nav-link" href="#">
                            <img th:src="${stp.getSession().get('avatar')}" alt="User Avatar" width="32" height="32"
                                class="rounded-circle me-2" style="border: 2px solid #ccc;">
                            <span id="username" th:text="${stp.getSession().get('username')}">用户名</span>
                        </a>
                    </li>
                    <li class="nav-item" sa:login>
                        <a class="btn btn-outline-danger" href="/logout">退出</a>
                    </li>
                </ul>
            </div>
        </div>
    </nav>

    <!-- Hero Section -->
    <section class="hero">
        <div class="container text-center">
            <h1 class="display-4">欢迎来到租车行者</h1>
            <p class="lead">为您提供方便、快捷的汽车租赁服务</p>
            <a href="/car/list" class="btn btn-outline-light btn-lg mb-2">立即租车</a>
        </div>
    </section>

    <!-- About Section -->
    <section class="about mt-5">
        <div class="container text-center">
            <h2 class="mb-4">关于我们</h2>
            <p class="lead">我们是一家致力于为客户提供高品质汽车租赁服务的公司。无论您是在旅途中还是需要暂时用车,我们都能满足您的需求。</p>
            <a href="#" class="btn btn-outline-primary">了解更多</a>
        </div>
    </section>

    <!-- Renting Process Section -->
    <section class="renting-process" style="margin-top:10%">
        <div class="container" id="steps">
            <h2 class="text-center mb-4">如何租车?</h2>
            <div class="row justify-content-center">
                <!-- Renting Process Cards -->
                <div class="col-md-4 mb-4">
                    <div class="card">
                        <div class="card-body">
                            <h5 class="card-title">1.选择车辆</h5>
                            <p class="card-text">在车辆库中选择您喜欢的车辆。</p>
                        </div>
                    </div>
                </div>
                <div class="col-md-4 mb-4">
                    <div class="card">
                        <div class="card-body">
                            <h5 class="card-title">2.提交租车申请</h5>
                            <p class="card-text">填写租车申请表格并提交。</p>
                        </div>
                    </div>
                </div>
                <div class="col-md-4 mb-4">
                    <div class="card">
                        <div class="card-body">
                            <h5 class="card-title">3.确认订单</h5>
                            <p class="card-text">等待我们确认订单并进行付款。</p>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </section>

    <!-- Footer -->
    <footer class="footer bg-light text-center">
        <div class="container">
            <span class="text-muted">&copy; 2024 汽车租赁系统</span>
        </div>
    </footer>

    <!-- Bootstrap Bundle with Popper -->
    <script src="https://cdn.jsdelivr.net/npm/@popperjs/core@2.11.6/dist/umd/popper.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/js/bootstrap.min.js"></script>

    <script>
        const driver = window.driver.js.driver;
        function helpMe() {
            const driverObj = driver({
                animate: true,
                showProgress: true,
                showButtons: ['next', 'previous', 'close'],
                prevBtnText: '上一步',
                nextBtnText: '下一步',
                doneBtnText: '结束引导',
                popoverClass: 'driverjs-theme',
                allowClose: true,
                // 是否自动滚动以使高亮元素可见
                scrollIntoViewOptions: {
                    behavior: 'smooth',
                    block: 'center'
                },
                steps: [
                    {
                        element: '#index',
                        popover: {
                            title: '这是首页',
                        }
                    },
                    {
                        element: '#torental',
                        popover: {
                            title: '租车点这里',
                            description: '你可以xxxxxxxxxxx'
                        }
                    }
                    ,
                    {
                        element: '#steps',
                        popover: {
                            title: '租车流程看这里',
                            description: '你可以xxxxxxxxxxx'
                        }
                    }
                ]
            });
            driverObj.drive();
        }
    </script>
</body>

</html>

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算法基础 - 并查集

&#x1f3e0;个人主页&#xff1a;尘觉主页 文章目录 算法 - 并查集前言Quick FindQuick Union加权 Quick Union路径压缩的加权 Quick Union比较&#x1f604;总结 算法 - 并查集 前言 用于解决动态连通性问题&#xff0c;能动态连接两个点&#xff0c;并且判断两个点是否连…

一个问题串联 Java 的几个基础知识

前言 关于 “” 和 equals() 的区别这个问题&#xff0c;我之前一直搞的很乱&#xff0c;虽然面试的时候一直没有被问到&#xff0c;但是我感觉这种是属于最基础的知识&#xff0c;如果不懂好像不是很好。后来我发现通过这个问题&#xff0c;可以串联起很多的知识点&#xff0…

使用Bitmaps位图实现Redis签到

系列文章目录 文章目录 系列文章目录前言前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。 Redis提供了Bitmaps这个“数据类型”可以实现对位的操作: (1) Bitmaps…

定时器与晶振时钟、中断系统、定时中断

定时器 简介&#xff1a; C51中的定时器和计数器是同一个硬件电路支持的&#xff0c;通过寄存器配置不同&#xff0c;就可以将他当做定时器 或者计数器使用。 确切的说&#xff0c;定时器和计数器区别是致使他们背后的计数存储器加1的信号不同。当配置为定时器使用时&#xff0…

求批量修改图片扩展名有哪些方法?一键批量修改文件扩展名

批量修改图片的扩展名还可以帮助我们更好地管理和分类图片。在日常生活和工作中&#xff0c;我们可能会收集大量的图片&#xff0c;这些图片可能来自不同的来源&#xff0c;具有不同的格式和特点。通过批量修改扩展名&#xff0c;我们可以将这些图片进行统一的管理和分类&#…

【JAVASE】学习类与对象的创建和实例化

✅作者简介&#xff1a;大家好&#xff0c;我是橘橙黄又青&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;再无B&#xff5e;U&#xff5e;G-CSDN博客 目标&#xff1a; 1. 掌握类的定义方式以及对象的实例化 2. …

视觉大模型--deter的深入理解

但对于transformer用于目标检测领域的开创性模型&#xff0c;该模型言简意赅&#xff0c;但是但从论文理解&#xff0c;有很多细节都不清楚&#xff0c;尤其是解码器的query和二分图匹配(Bipartite Matching)和匈牙利算法(Hungarian Algorithm)相关&#xff0c;本文将根据代码详…

Windows下Docker搭建Flink集群

编写docker-compose.yml 参照&#xff1a;https://github.com/docker-flink/examples/blob/master/docker-compose.yml version: "2.1" services:jobmanager:image: flink:1.14.4-scala_2.11expose:- "6123"ports:- "18081:8081"command: jobma…

基于ZooKeeper的Kafka分布式集群搭建与集群启动停止Shell脚本

下载Kafka压缩包 下方是Kafka官网下载地址&#xff0c;本文使用Kafka 3.0.0在虚拟机环境中搭建分布式集群。 Apache Kafka Downloads link 虽然在Kafka 2.8.0之后可以使用KRaft模式搭建高可用的集群以提高数据处理效率&#xff0c;但是目前还有许多企业依然使用ZooKeeper搭建K…

Docker实例

华子目录 docker实例1.为Ubuntu镜像添加ssh服务2.Docker安装mysql docker实例 1.为Ubuntu镜像添加ssh服务 (1)访问https://hub.docker.com&#xff0c;寻找合适的Ubuntu镜像 (2)拉取Ubuntu镜像 [rootserver ~]# docker pull ubuntu:latest latest: Pulling from library/ub…

SSM框架学习——了解MyBatis

了解MyBatis 什么是MyBatis MyBatis 是一款优秀的持久层框架&#xff0c;它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO&#xff…

计算机考研408有向无环图描述表达式可靠构造方法

目录 前言目标&#xff08;以王道书为例&#xff09;构造方法1. 建树2. 后序遍历1. a2. b3. 4. b5. c6. d7. 8. *9. *10. c 前言 对王道视频中的分层合并思想不是很满意&#xff0c;笔者提出自己的构造方法。 目标&#xff08;以王道书为例&#xff09; 构造方法 笔者通过王…

数据结构——二叉树(堆)

大家好我是小峰&#xff0c;今天我们开始学习二叉树。 首先我们来学习什么是树&#xff1f; 树概念及结构 树是一种 非线性 的数据结构&#xff0c;它是由 n &#xff08; n>0 &#xff09;个有限结点组成一个具有层次关系的集合。 把它叫做树是因 为它看起来像一棵倒挂的…

Python爬虫详解:原理、常用库与实战案例

前言 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家&#xff1a;https://www.captainbed.cn/z ChatGPT体验地址 文章目录 前言引言&#xff1a;一、爬虫原理1. HTTP请求与响应过程2. 常用爬虫技术 二、P…

基于ROS软路由的百元硬件升级方案实现突破千兆宽带

前言 很多用户得利于FTTR光网络不断推广&#xff0c;家用宽带带宽已经实现千兆速率的突破。而现在很多ISP运营商已经在多个城市率先推出2000M光宽带。这种情况下&#xff0c;要想将自家宽带的带宽能够充分发挥利用&#xff0c;就需要对原有的千兆设备进行升级来满足突破千兆的…

基于RFID技术的电缆温度监测方案及架构框架

在我们日常生活中&#xff0c;电力系统无处不在&#xff0c;为人类社会的发展提供了强大的动力支持。然而&#xff0c;在这个庞大的系统中&#xff0c;电缆作为传输电能的重要组成部分&#xff0c;其运行的安全性和稳定性至关重要。 随着城市化进程不断加快以及人们对用电需求的…

企业必备! 防员工偷懒神器,工作状况一目了然

在当前企业管理中&#xff0c;员工的工作状态和工作效率一直是管理者们关注的焦点。为了更加有效地监管员工的工作微信使用情况&#xff0c;微信管理系统成为了企业必备的神器。 这款系统不仅可以实时监控员工的工作微信&#xff0c;还具有多种实用功能&#xff0c;帮助企业管…

西电计科大三下SOC微体系结构设计作业合集

目录 一.VHDL设计作业 1.基于硬件描述语言的3-8译码器逻辑电路设计 2.8位双向移位寄存器设计 3.基于有限状态机的自助售票系统设计 4.按键消抖电路设计 5.同步环形FIFO设计 6.线上实验——时钟模块设计 7.线上实验——原码二位乘法器设计 8.线上实验——布斯乘法器设…

基于JSPM的宜佰丰超市进销存管理系统

目录 背景 技术简介 系统简介 界面预览 背景 互联网的迅猛发展彻底转变了全球众多组织的管理策略。自20世纪90年代起&#xff0c;中国政府和各类企事业单位便开始探索利用互联网技术进行信息管理。然而&#xff0c;由于当时网络覆盖不广泛、用户接受度不高、互联网相关法律…

苹果IPA上传错误排查:常见问题解决方案汇总

目录 引言 摘要 第二步&#xff1a;打开appuploader工具 第二步&#xff1a;打开appuploader工具&#xff0c;第二步&#xff1a;打开appuploader工具 第五步&#xff1a;交付应用程序&#xff0c;在iTunes Connect中查看应用程序 总结 引言 在将应用程序上架到苹果应用商…