Taro3.x 容易踩坑的点(阻止滚动穿透,弹框蒙层父级定位)

1 篇文章 0 订阅
1 篇文章 0 订阅
  1. 解决弹框滚动的时候,下层也会滚动问题=》阻止滚动穿透(react,vue)

案例描述:

页面展示时需要滚动条才可以显示完整,但是当我们显示弹框的时候,即使不需要滚动条,但是页面仍然可以滚动,并且下层内容会随着滚动变化。

阻止滚动穿透

Taro 3 的事件机制。因为事件都以 bind 的形式进行绑定,因此不能使用 e.stopPropagation() 阻止滚动穿透。

针对滚动穿透,目前总结了两种解决办法:

一、样式

使用样式解决:禁止被穿透的组件滚动

这也是最推荐的做法。

二、catchMove
Taro 3.0.21 版本开始支持

但是地图组件本身就是可以滚动的,即使固定了它的宽高。所以第一种办法处理不了冒泡到地图组件上的滚动事件。

需要真机预览或者模拟查看,pc模拟器上看不出效果。

在需要的弹框scroll-view 外层加上下面的内容包裹scroll-view 使用后真机上将不会滚动下层内容

<View catchMove></View>

  1. 解决弹框内部再显示其余的弹框,父级高度的定位限制,(RootPortal

root-portal 使整个子树从页面中脱离出来,类似于在 CSS 中使用 fixed position 的效果。主要用于制作弹窗、弹出层等。

案例描述:

以我项目中为例,使用了taro-ui的‘AtFloatLayout’组件,

项目中当我使用'AtFloatLayout'显示购物车后,内部又嵌套了一个‘AtModal’来展示点击购物车内部商品时出现切换规格的弹框;

此时如果不作处理,AtModal的最大高度是AtFloatLayout的高度,如果AtFloatLayout比较低AtModal无法再整个页面中上下居中显示,且可能会显示不全。

例如此图:未添加root-portal 的情况

解决方案:

<AtFloatLayout>
    <RootPortal>
        <AtModal></AtModal>
    </RootPortal>
</AtFloatLayout>

成功后模拟器element显示


解决后显示上下居中 以窗口最大为父级

成功解决弹框内部再显示其余的弹框高度的问题

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
taro3.x是一个基于React的多端开发框架,而ECharts是一个功能强大的数据可视化库。在taro3.x中使用ECharts可以实现数据可视化的效果,提供更丰富的交互和展示方式。 使用taro3.x配合ECharts可以实现以下步骤: 1. 安装依赖:通过npm或yarn安装echarts依赖,例如:npm install echarts --save。 2. 导入echarts:在使用的页面文件中导入echarts库,例如:import * as echarts from 'echarts'。 3. 创建图表容器:在页面的render方法中,通过将一个div元素设置为一个容器,并指定一个唯一的id作为容器的标识,用于后续初始化图表使用;例如:<div id="chartContainer"></div>。 4. 初始化图表:在页面的componentDidMount生命周期函数中,通过获取容器的id,并使用echarts.init方法初始化一个图表实例;例如:const chartDom = document.getElementById('chartContainer'); const myChart = echarts.init(chartDom)。 5. 配置图表参数:通过echarts的配置项进行参数的设置,例如设置图表的类型、数据、样式、交互等。可以参考ECharts官方文档,根据需求进行相应参数的配置;例如:const option = { ... }。 6. 渲染图表:将配置好的参数传入图表实例的setOption方法中,用于渲染图表;例如:myChart.setOption(option)。 通过以上步骤,就可以在taro3.x中使用ECharts实现数据可视化的效果。当然,根据具体的需求,还可以通过ECharts提供的API方法实现更多的交互和功能拓展,例如数据更新、动态加载等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Embrace924

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

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

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

打赏作者

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

抵扣说明:

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

余额充值