Smartour

编程之家收集整理的这个编程导航主要介绍了Smartour编程之家,现在分享给大家,也给大家做个参考。

Smartour 介绍

一旦网站改变了UI,通常他们会设置一个导游列表来告诉访问者,一些模块被移动到其他地方。 我们将其命名为“导游”,Smartour是一个使导游更容易的解决方案。 

在遇到网页内容有着较大调整的时候,往往需要一个导览功能去告诉用户,某某功能已经调整到另外一个位置。比较常规的办法是添加一个蒙层,高亮显示被调整的区域,然后通过文字介绍去完成引导。我们把这个功能称为“导览”,而 Smartour 则把这个导览的功能抽离出来,提供了一个开箱即用的解决方案。

Install

Smartour 被构建成了 umd 和 es module 模块,允许用户通过不同的方式引入。

npm install smartour

/* ES Modules */

import Smartour from 'smartour/dist/index.esm.js'

/* Commandjs */

const Smartour = require('smartour')

/* <script> */

<script src="smartour/dist/index.js"></script>

基本用法

Smartour 提供了一个非常简单的 API focus(),这是高亮一个元素最简单的方式。

let tour = new Smartour()

tour.focus({

el: '#basic-usage'

})

插槽 Slot

插槽 slot 是用于为高亮元素提供描述的 html 字符串。

纯字符串:

let tour = new Smartour()

tour.focus({

el: '#pure-string',

slot: 'This is a pure string'

})

html 字符串

let tour = new Smartour()

tour.focus({

el: '#html-string',

slot: `

<div>

<p>This is a html string</p>

</div>

`

})

插槽位置

插槽的位置可以选择4个不同的方向: top,right,left,bottom.

设置 options.slotPosition 属性即可覆盖默认的 top 位置。

let tour = new Smartour()

tour.focus({

el: '#slot-positions',

slot: `top`,

options: {

slotPosition: 'top' // 默认为 `top`

}

})

插槽事件

插槽所定义的元素也可以绑定事件。我们通过 keyNodes 属性来为插槽元素绑定事件。

keyNodes 是内容为一系列 keyNode 的数组。 属性 keyNode.el 是一个 css 选择器,而 keyNode.event 属性则是对应元素所绑定的事件。

let tour = new Smartour()

tour.focus({

el: '.slot-events-demo',

options: {

slotPosition: 'right'

},

slot: `

Click here to occur an alert event

</button>

Click here to occur an alert event

</button>

`,

keyNodes: [{

el: '.occur-1',

event: () => { alert('Event!!') }

},{

el: '.occur-2',

event: () => { alert('Another event!!') }

}]

})

Queue

有的时候页面需要不止一个导览。Smartour 允许你把一系列的导览通过 .queue() 放在一起,然后挨个挨个地展示它们。

举个例子:

let tour = new Smartour()

tour

.queue([{

el: '.li-1',

options: {

layerEvent: tour.next.bind(tour)

},

slot: 'This is the 1st line.'

},{

el: '.li-2',

slot: 'This is the 2nd line.'

},{

el: '.li-3',

slot: 'This is the 3rd line.'

}])

.run() // 别忘了调用 `run()` 方法去展示第一个导览

选项

Smartour 是一个构建函数,它接收一个 options 参数去覆盖其默认选项

让我们看看它的默认选项是什么样子的:

{

prefix: 'smartour',// class 前缀

padding: 5,// 高亮区域内边距

maskColor: 'rgba(0,.5)',// 带透明值的遮罩层颜色

animate: true,// 是否使用动画

slotPosition: 'top' // 默认的插槽位置

layerEvent: smartour.over // 遮罩层点击事件,默认为结束导览

}

APIs

除了 .focus(),.queue() 和 .run() API 以外,Smartour 还提供了另外三个 API 专门用于控制导览的展示。 

 .next():展示下一个导览(只能配合 .queue() 使用)。 

.prev():展示上一个导览(只能配合 .queue() 使用)。 

.over():结束全部导览。

Smartour 的原理

Smartour 通过 element.getBoundingClientRect() api 来获取目标元素的宽高和位置信息,然后放置一个带着 box-shadow 样式的元素在其之上作为高亮区域。

由于点击事件无法再 box-shadow 的区域里触发,所以 Smartour 还放置了一个全屏透明的遮罩层用于绑定 layerEvent 事件。

高亮区域和插槽都被设置为 absolute。当页面滚动时,document.documentElement.scrollTop 或者 document.documentElement.scrollLeft 的值就会变化,然后 Smartour 会实时修正它的位置信息。

 

网站地址:https://jrainlau.github.io/smartour/

GitHub:https://github.com/jrainlau/smartour

网站描述:让网页导览变得更简单

Smartour

官方网站:https://jrainlau.github.io/smartour/

小编说

以上是编程之家为你收集整理的Smartour全部内容。

如果觉得编程之家网站内容还不错,欢迎将编程之家推荐给好友。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


scalable.js,一款可以使任何HTML元素动态缩放适合父元素的js插件
Pica,使用JS进行快速高品质图像缩放
react-dates,React 日期组件
date-fns,轻量级的JavaScript 日期工具库
WOW.js,一款效果炫酷的元素在页面滚动时展示CSS3动画的JS插件
Pikaday,一个 轻量级、无依耐Js日期选择器
ngDialog,一个基于AngularJS的扩展对话框模块
react-swipeable-views,一个 React 轮播组件
lazysizes.js,响应式图像延迟加载JS插件【懒加载】
Flickity,一款自适应手机触屏滑动插件
screenfull.js,浏览器全屏插件
ueditor,由百度web前端研发部开发所见即所得富文本web编辑器
Darkmode.js,一键为网站添加黑暗模式
PhotoClip.js,一款手势驱动的裁图插件
react-native-masonry,用于渲染一个图像masonry~ish布局react-native组件
PixelMatch,一个最小、最简单、最快的js像素级图像比较库
number-flip,一款 js 数字翻转切换插件
vue-core-image-upload,图片剪切和上传的 vue 插件
vue-awesome-swiper,基于swiper、Vue.js 的 Swiper 组件
hashids.js,数字生成类似YouTube的ID的js库