plugins/movable
优质
小牛编辑
139浏览
2023-12-01
介绍
movable 插件为 BetterScroll 拓展可移动拖拽的能力。
安装
npm install @better-scroll/movable --save
// or
yarn add @better-scroll/movable
基本使用
首先引入 movable 插件,并通过全局方法 BScroll.use()
注册插件
import BScroll from '@better-scroll/core'
import Movable from '@better-scroll/movable'
BScroll.use(Movable)
上面步骤完成后,需要在 options
中传入正确的配置:
new BScroll('.bs-wrapper', {
bindToTarget: true,
scrollX: true,
scrollY: true,
freeScroll: true,
bounce: true
movable: true // for movable plugin
})
以下是移动插件专属以及 BetterScroll 的配置:
movable<插件专属>
开启 movable 功能,必须设置为
true
,若没有该项,则插件不会生效。bindToTarget
必须设置为
true
,主动将 touch 事件绑定在待移动的元素上,因为BetterScroll 默认将 touch 事件在绑定容器元素(wrapper)上。freeScroll
记录 x 和 y 轴的手指偏移量,设置为
true
。同时需要设置 scrollX 和 scrollY 均为 true。scrollX
开启 x 轴方向滚动能力,设置为
true
。scrollY
开启 y 轴方向滚动能力,设置为
true
。bounce
指定开启边界回弹。
示例
{ bounce: true // 开启四个方向, bounce: { left: true, // 开启左边界回弹 right: true, // 开启右边界回弹 top: false, bottom: false } }
示例
只有一个 content
通常场景下,只存在一个 content。
<<< @/examples/vue/components/movable/default.vue?template <<< @/examples/vue/components/movable/default.vue?script <<< @/examples/vue/components/movable/default.vue?style多个 content
但是在某些场景下,可能存在多个 content。
<<< @/examples/vue/components/movable/multi-content.vue?template <<< @/examples/vue/components/movable/multi-content.vue?script <<< @/examples/vue/components/movable/multi-content.vue?style
进阶使用
搭配 zoom 插件,增加缩放能力。
import BScroll from '@better-scroll/core'
import Movable from '@better-scroll/movable'
import Zoom from '@better-scroll/zoom'
new BScroll('.bs-wrapper', {
bindToTarget: true,
scrollX: true,
scrollY: true,
freeScroll: true,
bounce: true
movable: true // for movable plugin
zoom: { // for zoom plugin
start: 1,
min: 1,
max: 3
}
})
示例
:::warning zoom 暂不支持在 pc 端的交互操作,下方 demo 请扫码体验。 :::
一个 content
<<< @/examples/vue/components/movable/scale.vue?template <<< @/examples/vue/components/movable/scale.vue?script <<< @/examples/vue/components/movable/scale.vue?style多个 content
<<< @/examples/vue/components/movable/multi-content-scale.vue?template <<< @/examples/vue/components/movable/multi-content-scale.vue?script <<< @/examples/vue/components/movable/multi-content-scale.vue?style
实例方法
putAt(x, y, [time], [easing])
参数
{PositionX} x
: x 坐标PositionX:'number | 'left' | 'right' | 'center'
{PositionY} y
: y 坐标PositionY:'number | 'top' | 'bottom' | 'center'
{number} [time]<可选>
:滚动的动画时长{EaseItem} [easing]<可选>
:缓动效果配置,参考 ease.ts,默认是bounce
效果
将 content 元素放置在某一个位置。x 与 y 不仅可以是数字,也可以是对应的字符串。
示例
const bs = new BScroll('.bs-wrapper', { bindToTarget: true, scrollX: true, scrollY: true, freeScroll: true, movable: true }) bs.putAt('center', 'center', 0) // 放置在 wrapper 的正中心 bs.putAt('right', 'bottom', 1000) // 放置在 wrapper 的右下角,动画时长 1s