解决微信小程序在iOS 系统上echarts不能滑动的问题
在微信小程序中使用echarts
插件的时候,遇到了一个问题:当系统是iOS
时,如果手指先是长按图表,然后页面会无法滑动,其中南丁格尔玫瑰图尤其明显。作为一个微信小程序的新手开发,这个问题属实难倒我了。
解决方案
1.添加遮罩层
使用一个遮罩层覆盖echarts
图表,这样的话,当长按并滑动页面的时候,滑动的就是这个遮罩层了,自然就可以解决问题。
遇到的问题:
canvas
是原生组件,层级很高,view
无法作为遮罩层。我使用的是cover-view
作为遮罩层。<cover-view wx:if="{{isIOS}}" class="echart-mask" ></cover-view> <e-chart chart-class='echart' option='{{ data.getEChartOption(employeeInfoList) }}' bindinstance='getEchartInstance' />
- 再添加了遮罩层之后,在
iOS
系统上可以正常滑动,但是在Android
系统上又无法滑动了(真是风水轮流转 ̄へ ̄)。我是在页面上对系统进行判断,以决定是否创建遮罩层。wx.getSystemInfo({ success: (result) =>this.setData({ isIOS: result.system.match(/iOS/) }), });
2. 将图表转为图片展示
因为echarts
图标在我这只是进行数据展示,而不会与用户进行交互,所以也考虑到了在echarts的过渡动画走完之后,用图片来代替echarts
组件。
getEchartInstance({ detail: echart }) { echart.on('finished', () = >{ echart.getDom().saveAsImage().then((path) = >{ this.setData({ homeworkCountEchartImg: path }); }); }); },
遇到的问题:
在图片替换echarts
的时候,出现了一次闪烁。要注意在图片加载完毕之后再移除echarts
,可以使用image
的bindload
来控制。
3. 使用echart
插件的disableTouch
属性。
在option
对象的根目录,添加disableTouch
属性,设为true即可。这是微信echarts
插件官方技术人员给出的一种解决方案。
var eChartOption = { disableTouch: true, //解决ios系统,echarts长按不能滑动的问题 color: [ '#79db66', '#769efd', '#f6994f', '#f5df4e', '#a668f5', '#66cbdb', '#dc76fd', '#6062e0', '#ec7997', '#88e6be', ], legend: { selectedMode: false, show: false, }, }
以上就是解决微信小程序在iOS 系统上echarts不能滑动的问题方法,希望对需要的小伙伴有帮助。
使用声明:
1. 本站所有素材(未指定商用),仅限学习交流。
2. 会员在本站下载的VIP素材后,只拥有使用权,著作权归原作者及码云笔记网所有。
3. 原创商用和VIP素材,未经合法授权,请勿用于商业用途,会员不得以任何形式发布、传播、复制、转售该素材,否则一律封号处理。
4. 本平台织梦模板仅展示和个人非盈利用途,织梦系统商业用途请预先授权。
码云笔记 » 解决微信小程序在iOS 系统上echarts不能滑动的问题
1. 本站所有素材(未指定商用),仅限学习交流。
2. 会员在本站下载的VIP素材后,只拥有使用权,著作权归原作者及码云笔记网所有。
3. 原创商用和VIP素材,未经合法授权,请勿用于商业用途,会员不得以任何形式发布、传播、复制、转售该素材,否则一律封号处理。
4. 本平台织梦模板仅展示和个人非盈利用途,织梦系统商业用途请预先授权。
码云笔记 » 解决微信小程序在iOS 系统上echarts不能滑动的问题