uniapp的movable-view、movable-area

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>

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
movable-view是一个可移动的视图容器,在页面中可以通过拖拽滑动来改变其位置。它通常与movable-area一起使用,movable-areamovable-view的父级容器,必须设置width和height属性,否则默认为10px。\[1\] 注意事项包括: 1. movable-viewmovable-area都必须设置width和height属性,否则默认为10px。 2. movable-view默认为绝对定位,top和left属性为0px。 3. movable-view移动范围限制在movable-area内,如果movable-view的宽或高值比movable-area大,则只能在x或y方向移动,若都超过,则无法移动。 4. movable-view必须在组件中,并且必须是直接子节点,否则不能移动。\[2\] 在微信小程序中,movable-view是一个独有的模块,它有两个标签:movable-area作为父容器,movable-view作为子容器。子容器必须在父容器中,否则无法实现移动效果。\[3\] 下面是一个示例代码,展示了如何使用movable-viewmovable-area来创建一个可移动的红色视图: ```html <movable-area class='area'> <movable-view class='a' direction='all' inertia out-of-bounds="{{false}}" x="{{x*2}}rpx" y="{{y*2}}rpx" damping='30' friction="30"> 我是红色 </movable-view> </movable-area> <button bind:tap="areaEvent">按钮</button> ``` 在这个示例中,movable-view被设置为红色,并且可以通过拖拽滑动来改变其位置。\[3\] #### 引用[.reference_title] - *1* *2* [uni-app视图容器之movable-view](https://blog.csdn.net/qq_27600723/article/details/106452491)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [手把手带你学习微信小程序 —— 九 (movable-view 组件)](https://blog.csdn.net/caidewei121/article/details/96352443)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

秋叶原的琴音

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

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

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

打赏作者

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

抵扣说明:

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

余额充值