driver.js web 新手交互引导工具库

news2024/9/22 17:32:31

前言

最近逛技术论坛发现了 driver.js 这个库,相信很多人在app中都碰到过功能引导的,这个库就可以用来做这个功能。web段项目很少见到功能引导的,但是用在uniapp浏览器插件 中感觉还是十分不错的,因此打算来简单学习一下,防止以后会用到。

文档地址:https://github.com/kamranahmedse/driver.js
官方demo:https://kamranahmed.info/driver.js/

下面只演示最基本的使用,其他见官方示例

安装、使用

安装

npm install driver.js

基本使用
最简单的使用方法是高亮突出一个元素,只要给一个 CSS 选择器即可

<template>
    <div>
        <div class="test">driver.js的基本使用</div>
        <div>111</div>
        <div>222</div>
        <div>333</div>
    </div>
</template>

<script>
import Driver from 'driver.js';
import 'driver.js/dist/driver.min.css';
export default {
    mounted() {
        const driver = new Driver();
        driver.highlight({
            element: '.test',
            popover: {
                title: '这是个标题',
                description: '描述:这是一个弹出层',
                // 位置支持设置为 left, left-center, left-bottom, top,
                // top-center, top-right, right, right-center, right-bottom,
                // bottom, bottom-center, bottom-right, mid-center
                position: 'top',
                // 偏移
                offset: 20
            }
        });
    }
};
</script>

<style lang="scss" scoped>
.test {
    color: blue;
}

div {
    width: 200px;
    height: 30px;
}
</style>

在这里插入图片描述
多步骤引导

<template>
    <div>
        <div  id="first">第一步</div>
        <div id="second">第二步</div>
        <div id="third">第三步</div>
    </div>
</template>

<script>
import Driver from 'driver.js';
import 'driver.js/dist/driver.min.css';
export default {
    mounted() {
        const driver = new Driver();
        // 定义步骤
        driver.defineSteps([
            {
                element: '#first', // 元素
                popover: {
                    title: '提示',
                    description: '第一步',
                    position: 'left'
                }
            },
            {
                element: '#second',
                popover: {
                    title: '提示',
                    description: '第二步',
                    position: 'top'
                }
            },
            {
                element: '#third',
                popover: {
                    title: '提示',
                    description: '第三步',
                    position: 'right'
                }
            }
        ]);
        // 开始引导,参数表示默认开始的标识
        driver.start(0);
        setTimeout(() => {
            // 如果存在下一步
            if (driver.hasNextStep()) {
                // 移动到下一步
                driver.moveNext();
            }
        }, 500);
        setTimeout(() => {
            // 如果存在上一步
            if (driver.hasPreviousStep()) {
                // 移动到下一步
                driver.movePrevious();
            }
        }, 1500);
    }
};
</script>

<style lang="scss" scoped>
div {
    width: 200px;
    height: 30px;
     color: blue;
}
</style>

在这里插入图片描述

<template>
    <div>
        <div  id="first">第一步</div>
        <div id="second">第二步</div>
        <div id="third">第三步</div>
    </div>
</template>

<script>
import Driver from 'driver.js';
import 'driver.js/dist/driver.min.css';
export default {
    mounted() {
        const driver = new Driver({
            // 不允许点击遮罩关闭
            allowClose: false
        });
        // 定义步骤
        driver.defineSteps([
            {
                element: '#first', // 元素
                popover: {
                    title: '提示',
                    description: '第一步',
                    position: 'left'
                }
            },
            {
                element: '#second',
                popover: {
                    title: '提示',
                    description: '第二步',
                    position: 'top'
                }
            },
            {
                element: '#third',
                popover: {
                    title: '提示',
                    description: '第三步',
                    position: 'right'
                }
            }
        ]);
        // 开始引导,参数表示默认开始的标识
        driver.start(0);
        setTimeout(() => {
            // 如果存在下一步
            if (driver.hasNextStep()) {
                // 移动到下一步
                driver.moveNext();
            }
        }, 500);
        setTimeout(() => {
            // 如果存在上一步
            if (driver.hasPreviousStep()) {
                // 移动到下一步
                driver.movePrevious();
            }
        }, 1500);
    }
};
</script>

<style lang="scss" scoped>
div {
    width: 200px;
    height: 30px;
     color: blue;
}
</style>

注:电脑上左右健,可以来切换步骤。

常用配置、方法

配置

// 以下的值都是默认值
const driver = new Driver({
  animate: true,                    // 是否开启动画
  opacity: 0.75,                    // 遮罩透明度
  padding: 10,                      // padding
  allowClose: true,                 // 点击遮罩是否可以关闭
  overlayClickNext: false,          // 点击遮罩进行下一步
  doneBtnText: 'Done',              // 最后一共按钮的文本
  closeBtnText: 'Close',            // 关闭按钮的文本
  stageBackground: '#ffffff',       // 突出元素的背景色
  nextBtnText: 'Next',              // 下一步按钮的文本
  prevBtnText: 'Previous',          // 上一步按钮的文本
  showButtons: false,               // 不显示控制按钮
  keyboardControl: true,            // 是否允许通过键盘的左右键来控制
  scrollIntoViewOptions: {},        // 滚动视图配置,暂时不知道如何使用
  onHighlightStarted: (Element) => {}, // 元素高亮开始事件
  onHighlighted: (Element) => {},      // 元素高亮事件
  onDeselected: (Element) => {},       // 取消选定事件
  onReset: (Element) => {},            //重置事件
  onNext: (Element) => {},                    // 下一步
  onPrevious: (Element) => {},                //上一步
});

定义步骤

const stepDefinition = {
  element: '#some-item',        // 元素对象,支持类和id
  stageBackground: '#ffffff',   // 突出框背景色
  popover: {                    // There will be no popover if empty or not given
    className: 'popover-class', // 弹出窗口样式
    title: 'Title',             // 标题
    description: 'Description', // 描述
    showButtons: false,         // 是否显示按钮
    doneBtnText: 'Done',        
    closeBtnText: 'Close',     
    nextBtnText: 'Next',       
    prevBtnText: 'Previous',  
  },
  onNext: () => {},             // 从当前步骤移动到下一步骤时调用
  onPrevious: () => {},         // 从当前步骤移动到上一步骤时调用
};

常用方法

const driver = new Driver(driverOptions);

// 检查驱动程序是否激活
if (driver.isActivated) {
    console.log('Driver is active');
}

// 定义步骤列表
driver.defineSteps([ stepDefinition1, stepDefinition2, stepDefinition3 ]);
driver.start(stepNumber = 0);  // 开始执行定义的步骤
driver.moveNext();             // 移动到下一步
driver.movePrevious();         // 移动到上一步
driver.hasNextStep();          // 是否存在下一步
driver.hasPreviousStep();      // 是否存在上一步

// 停止移动
driver.preventMove();

// 使用查询选择器或步骤定义突出显示元素
driver.highlight(string|stepDefinition);

// 重新定位弹出窗口和高亮显示的元素
driver.refresh();

// 重置覆盖并清除屏幕
driver.reset();

// 检查是否有任何突出显示的元素
if(driver.hasHighlightedElement()) {
    console.log('There is an element highlighted');
}

// 获取屏幕上当前突出显示的元素
const activeElement = driver.getHighlightedElement();

// 获取最后一个突出显示的元素
const lastActiveElement = driver.getLastHighlightedElement();

activeElement.getCalculatedPosition(); // 获取活动元素的屏幕坐标
activeElement.hidePopover();           // 隐藏弹框
activeElement.showPopover();           // 显示弹框

activeElement.getNode();  // 获取当前突出元素下的dom元素

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

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

相关文章

js 防抖函数 节流函数

某些事件中(如 onresize onscroll onkeydown onkeyup onmousemove …)&#xff0c;会连续触发函数的执行&#xff0c;如果函数执行一些耗时的操作(如请求数据…)&#xff0c;会影响性能&#xff0c;也有可能造成服务器压力。这时可以用 防抖函数 或 节流函数解决这种问题。 防…

分布式环境下的服务器时钟同步问题解决办法

一、分布式集群场景下时钟不同步会有什么问题&#xff1f; 如上面的示意图所示&#xff0c;分布式集群场景下如果各个服务器时间不一致&#xff0c;可能导致同一时间产生的数据&#xff0c;在处理过程中和数据库中&#xff0c;保存成了不同的时间&#xff0c;造成数据混乱。 …

大数据之Phoenix环境搭建

文章目录前言一、下载Phoenix安装包二、上传并解压三、拷贝服务包到各个hbase的lib目录下四、修改hbase的配置文件五、重启HBase集群六、连接Phoenix客户端前言 #博学谷IT学习技术支持# 本篇文章主要介绍Phoenix的环境搭建&#xff0c;Phoenix支持使用SQL语句操作HBase&#x…

JavaWeb6-线程常用方法

目录 1.线程等待join&#xff08;共有3个方法重载&#xff09; 1.1.public void join() 1.2.public void join(long millis) 2.线程终止 2.1.通过自定义标记符来中断&#xff08;常用&#xff09; 2.2.调用 interrupt() 方法来中断&#xff08;常用&#xff0c;最推荐使用…

Ubuntu安装落雪音乐LX Music

网址&#xff1a; https://lxmusic.toside.cn/ 以 .deb 结尾的文件为在 Linux 系统上运行的版本&#xff0c;软件还有 .rpm/AppImage/pacman 格式的 Linux 包&#xff0c;但没有上传到网盘&#xff0c;可自行到项目发布页面下载。 在Ubuntu上安装比较简单。 安装成功 打开音乐…

maven多环境配置

maven多环境配置 参考网址: https://mp.weixin.qq.com/s/-e74bd2wW_RLx7i4YF5M2w https://mp.weixin.qq.com/s/3p53kBHqys58QdMme6lR4A 项目地址 https://gitee.com/shao_ming314/maven-profile-dir 项目说明 该项目基于目录进行多环境配置 , 具体的配置文件在 src/resource…

【Opencv--自适应图像二值化】cv2.adaptiveThreshold()

【Opencv–adaptiveThreshold】自适应阈值图像二值化 文章目录【Opencv--adaptiveThreshold】自适应阈值图像二值化1. 介绍2. adaptiveThreshold函数2.1 函数调用2.2 补充说明3. 代码示例4. 效果4.1 原图&#xff08;ori.img&#xff09;4.2 处理后5. 参考1. 介绍 在这里 cv2.…

ArcGIS Enterprise on Kubernetes 11.0安装示例

博客主页&#xff1a;https://tomcat.blog.csdn.net 博主昵称&#xff1a;农民工老王 主要领域&#xff1a;Java、Linux、K8S 期待大家的关注&#x1f496;点赞&#x1f44d;收藏⭐留言&#x1f4ac; 目录安装前置条件基本安装解压文件生成秘钥执行安装脚本配置DNS方法一方法二…

快速上手:Prometheus和Grafana入门教程

目录一、简介二、安装Prometheus2.1 二进制安装2.2 添加到system服务2.3 访问UI三、安装Granfa3.1 Docker部署Mysql3.2 Docker部署Grafana3.3 访问UI3.4 添加Prometheus为数据源四、安装Exporter收集数据4.1 node_exporter 服务器监控下载解压启动node_exporter服务与整合Prome…

聚类-理论补充2

目录 一。拉普拉斯矩阵的定义 二。谱聚类算法&#xff1a;未正则拉普拉斯矩阵 三。谱聚类算法&#xff1a;随机游走拉普拉斯矩阵 四。谱聚类算法&#xff1a;对称拉普拉斯矩阵 五。进一步思考 六。随机游走和拉普拉斯矩阵的关系 七。标签传递算法 一。拉普拉斯矩阵的定义 …

MySQL(六)

查询优化 在编写快速的查询之前&#xff0c;需要清楚一点&#xff0c;真正重要的是响应时间&#xff0c;而且要知道在整个SQL语句的执行过程中每个步骤都花费了多长时间&#xff0c;要知道哪些步骤是拖垮执行效率的关键步骤&#xff0c;想要做到这点&#xff0c;必须要知道查询…

Qt之调色板类QPalette的使用

文章目录QPalette调色板类前言代码知识点讲解QPalette调色板类 前言 Qt提供的调色板类QPalette专门用于管理部件的外观显示&#xff0c;相当于部件或对话框的调色板&#xff0c;管理他们所有的颜色信息。每个部件都包含一个QPalette对象&#xff0c;在显示时&#xff0c;按照…

OnGUI Color 控件||Unity 3D GUI 简介||OnGUI TextField 控件

Unity 3D Color 控件与 Background Color 控件类似&#xff0c;都是渲染 GUI 颜色的&#xff0c;但是两者不同的是 Color 不但会渲染 GUI 的背景颜色&#xff0c;同时还会影响 GUI.Text 的颜色。具体使用时&#xff0c;要作如下定义&#xff1a;public static var color:Color;…

Go 管道关闭引发的探索

前言 在日常开发中, 经常会使用chan来进行协程之间的通信. 对chan的操作也无外乎读写关. 而本次, 就是从chan的关闭而来. 假设我们对外提供的方法如下: type Chan struct {ch chan int }func (c *Chan) Close() {close(c.ch) }func (c *Chan) Send(v int) {c.ch <- v }那…

Qt 工程师进阶技术23种设计模式

Qt 工程师进阶技术23种设计模式【1】23种设计模式【1】23种设计模式 设计模式是解决特定问题的一系列套路&#xff0c;这套方案提高代码可复用性、可读性、稳健性、可维护性及安全性。 23种设计模式可分为三类:结构型模式(侧重类与对象之间的组合)、行为型模式&#xff08;侧重…

day47【代码随想录】动态规划之买卖股票的最佳时机III、买卖股票的最佳时机IV、最佳买卖股票时机含冷冻期、买卖股票的最佳时机含手续费

文章目录前言一、买卖股票的最佳时机III&#xff08;力扣123&#xff09;二、买卖股票的最佳时机IV&#xff08;力扣188&#xff09;三、最佳买卖股票时机含冷冻期&#xff08;力扣309&#xff09;四、买卖股票的最佳时机含手续费&#xff08;力扣714&#xff09;股票买卖问题总…

office365 word 另存为 pdf 的注意事项和典型设置

0. 操作环境介绍 Office 版本&#xff1a;Office 365 版本 不同版本的操作可能有所不同 1. 基本操作 – 另存为 pdf 【文件】 --> 【另存为】&#xff0c;选择适当的文件路径、文件名保存类型选择【PDF】点击【保存】 1. 导出的pdf包含目录标签 word中&#xff0c;可使用…

Head First设计模式---1.策略模式

4.1策略模式&#xff1a; 策略模式是一种行为设计模式&#xff0c; 它能让你定义一系列算法&#xff0c; 并将每种算法分别放入独立的类中&#xff0c; 以使算法的对象能够相互替换。 问题 一天&#xff0c;我们需要做一个鸭子游戏&#xff0c;游戏中会出现各种鸭子&#xff…

掘金数据时代2022年度隐私计算评选活动火热报名中!

开放隐私计算 开放隐私计算开放隐私计算OpenMPC是国内第一个且影响力最大的隐私计算开放社区。社区秉承开放共享的精神&#xff0c;专注于隐私计算行业的研究与布道。社区致力于隐私计算技术的传播&#xff0c;愿成为中国 “隐私计算最后一公里的服务区”。183篇原创内容公众号…

全网最全虚拟机的封装

1.服务器初始化 系统环境RHEL7.6 2.禁用selinux [rootserver1 ~]# vim /etc/sysconfig/selinux SELINUXdisabled reboot 3.禁用防火墙 [rootserver1 ~]# systemctl disable --now firewalld 4.配置yum源 [rootserver1 ~]# vim /etc/fstab /dev/mapper/rhel…