uniapp的movable-view、movable-area

文章详细介绍了uniapp框架中movable-view和movable-area组件的使用方法,包括它们的属性设置、事件监听以及各种示例,如拖动范围、移动方向限制、超出边界、惯性和缩放效果等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

uniapp的movable-view、movable-area

movable-view:

  • 可以在页面中拖拽滑动
  • 必须在movable-area组件中,并且必须是直接子节点
  • 必须设置width和height属性,不设置默认为10px
  • 提供特殊事件:htouchmove和vtouchmove

movable-area:

  • 表示可拖动的范围
  • 可包含多个movable-view组件
  • 必须设置width和height属性,不设置默认为10px

以下是完整示例代码

movable-view 区域小于 movable-area
<view class="uni-title uni-common-mt">
	示例 1
	<text>\nmovable-view 区域小于 movable-area</text>
</view>
<movable-area>
	<movable-view :x="x" :y="y" direction="all" @change="onChange">text</movable-view>
</movable-area>
<view @tap="tap" class="uni-link uni-center uni-common-mt">
	点击这里移动至 (30px, 30px)
</view>

<script>
	export default {
		data() {
			return {
				x: 0,
				y: 0,
				scale: 2,
				old: {
					x: 0,
					y: 0,
					scale: 2
				}
			}
		},
		methods: {
			tap: function(e) {
				// 解决view层不同步的问题
				this.x = this.old.x
				this.y = this.old.y
				this.$nextTick(function() {
					this.x = 30
					this.y = 30
				})
			},
			onChange: function(e) {
				this.old.x = e.detail.x
				this.old.y = e.detail.y
			}
		}
	}
</script>

在这里插入图片描述

nmovable-view区域大于movable-area
<view class="uni-title uni-common-mt">
示例 2
	<text>\nmovable-view区域大于movable-area</text>
</view>
<movable-area>
	<movable-view class="max" direction="all">text</movable-view>
</movable-area>

在这里插入图片描述

只可以横向移动
<view class="uni-title uni-common-mt">
	示例 3
	<text>\n只可以横向移动</text>
</view>
<movable-area>
	<movable-view direction="horizontal">text</movable-view>
</movable-area>

在这里插入图片描述

只可以纵向移动
<view class="uni-title uni-common-mt">
	示例 4
	<text>\n只可以纵向移动</text>
</view>
<movable-area>
	<movable-view direction="vertical">text</movable-view>
</movable-area>

在这里插入图片描述

可超出边界
<view class="uni-title uni-common-mt">
	示例 5
	<text>\n可超出边界</text>
</view>
<movable-area>
	<movable-view direction="all" out-of-bounds>text</movable-view>
</movable-area>

在这里插入图片描述

带有惯性
<view class="uni-title uni-common-mt">
	示例 6
	<text>\n带有惯性</text>
</view>
<movable-area>
	<movable-view direction="all" inertia>text</movable-view>
</movable-area>

在这里插入图片描述

可缩放
<view class="uni-title uni-common-mt">
	示例 7
	<text>\n可放缩</text>
</view>
<movable-area scale-area>
	<movable-view direction="all" @scale="onScale" scale scale-min="0.5" scale-max="4" :scale-value="scale">text</movable-view>
</movable-area>
<view @tap="tap2" class="uni-link uni-center uni-common-mt" style="padding-bottom:80rpx;">
	点击这里放大3倍
</view>

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋叶原的琴音

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值