小程序双指缩放问题记录

需求

开发使用的是uni-app去开发的小程序,然后使用了u-view2这个框架,接受一个富文本,富文本里面主要是表格,数据比较多,然后用户希望,表格完整显示,再支持用户双指缩放+放大了去移动

碰到问题

碰到这个问题,一开始想法是监听用户的手指移动事件就可以了,因为有@touchstart@touchmove事件,然后手写出来,发现效果并不好,卡顿,应该是我写的问题。

查看文档发现了movable-area, movable-view 这两个,于是开始我的爬坑之旅

官方文档

1:movable-view缩放不是用户的手指中心

2:我配置了的movable-view的direction= 'all' 无法竖向滚动,好像只有放大了可以拖到

查看了微信社区,得到的答案就是还没有解决

最新的关于这个组件的这个问题,也是没有回复和解决办法。

解决方法

配合scroll-view来实现。

但其实我尝试了很多其他办法,其实还有一种办法是图片来实现,但用户需要改变数据,存储的又是富文本的表格数据,我去处理这个,相当于给我找事做,所以我只能继续优化。

一开始我的代码配置是(我的富文本内容很多大概是100kb~5mb的 都有不同数据,所以这个表格很长)

ruby 复制代码
<movable-area :scale-area="true" class="area">
	<movable-view class="area-view" :scale="true" direction="horizontal" :scale-min="0.5" :scale-max="5"  @scale="scaleMove" :scale-value="scaleFactor" @click="dblclick">
	<scroll-view :scroll-y="true" style="height: 100vh;">
		<view class="child">
			<u-parse :content="content"></u-parse>
		</view>
			</scroll-view>
		</movable-view>
   </movable-area> 

【area和view都是需要给宽高的被人默认是10,文档有说】

其实不添加scroll-view 就使用movable-area+ movable-view 已经可以让我这个富文本表格可以缩放和滚动,需要把movable-view的direction="horizontal" 这样。 但碰到问题是ios也就是苹果用户,出现了个无法拉到底部的问题,也就是放大后顶部明明还有数据但是无法啦下去的问题!然后缩放中心不是用户手指

但是添加了scroll-view 同时我去配置了child的css代码

css 复制代码
.child {
    width: 200%;
    height: 100%;
    transform: scale(0.5);
    transform-origin: left top;
}

这样我发现中心是手指的中心了,但我碰到了问题,就是这个双指缩放,不是每一次都生效,后面感觉是scroll-view和movable-view冲突了把!应该。

再优化!

ruby 复制代码
<scroll-view scroll-y :style="{'width': width, 'height': '100vh'}" >
            <movable-area :style="{'width': width, 'height': '100vh'}">
                    <movable-view :style="{'width': width, 'height': '100vh'}" :animation="false" @scale="scaleMove" 
                            direction="horizontal" :scale="true" :scale-min="1" :scale-max="5">
                            <view class="block" v-show="showBlock"></view>
                            <view class="child">
                                    <u-parse :content="content"></u-parse>
                            </view>
                    </movable-view>
            </movable-area>
    </scroll-view>

这就是我目前的办法!

我把scroll-view配置到了最外面,然后让宽为屏幕的宽度,使用 uni.getSystemInfoSync().windowWidth; 获取,然后高度100%,然后我发现效果都非常不错!解决了缩放中心是手指的,然后也可以去放大移动!不卡顿,

但是!!!!!

又发现,放大后无法滚动到顶部!!,顶部还有内容,但无法再滑上去了,我打印了 @scale="scaleMove" 里面获取的x 值发现, x已经为0了 所以无法拖动 为了解决这个问题

我在child 上再写一个block 块 给个固定高度,在用户缩放的时候显示, 然后这个时候,就不存在无法滚动到顶部了,内容都可以完整呈现出来

ini 复制代码
scaleMove(event) {
    let val = event.detail.scale
    this.showBlock = Math.round(val) !== 1;
}

但其实并不完美,因为添加了这个元素,缩放的中心在变化!莫名其妙 ~ ~ ,还有就是顶部有一个空白区域,希望有更好的解决办法 ~ ~

总结

先mark一下把,后面有更好的办法了,回来优化!

相关推荐
00后程序员张5 小时前
Fiddler抓包工具使用教程,代理设置与调试方法实战解析(含配置技巧)
前端·测试工具·ios·小程序·fiddler·uni-app·webview
笨笨狗吞噬者14 小时前
【uniapp】体验优化:开源工具集 uni-toolkit 发布
性能优化·微信小程序·uni-app
知识分享小能手16 小时前
微信小程序入门学习教程,从入门到精通,自定义组件与第三方 UI 组件库(以 Vant Weapp 为例) (16)
前端·学习·ui·微信小程序·小程序·vue·编程
NoneSL17 小时前
Uniapp UTS插件开发实战:引入第三方SDK
前端·uni-app
爱隐身的官人18 小时前
微信小程序反编译教程
微信小程序·小程序·小程序反编译
计算机徐师兄20 小时前
Java基于SpringBoot的智慧校园管理系统小程序【附源码、文档说明】
java·微信小程序·小程序·智慧校园管理系统小程序·java智慧校园管理系统小程序·智慧校园管理系统微信小程序·智慧校园管理微信小程序
毕设源码-赖学姐20 小时前
【开题答辩全过程】以 宝贝回家网微信小程序为例,包含答辩的问题和答案
微信小程序·小程序
_AaronWong1 天前
微信小程序同声传译插件接入实战:语音识别功能完整实现指南
前端·微信小程序·uni-app
赵庆明老师1 天前
Uniapp微信小程序开发:http请求封装。
http·微信小程序·uni-app
雪芽蓝域zzs1 天前
uniapp AES 加密解密
开发语言·uni-app·c#