WX小程序组件不支持hidden属性(uni-app v-show直接作用在自定义的在组件上不起作用)

问题描述

  1. 今天在工作中,同事使用uni-app开发,想利用v-show指令实现页面内容切换,结果在微信小程序中,页面的内容全部显示出来了。
  2. 看到这个现象,就怀疑 v-show 是否在微信小程序中起作用

过程分析

  1. 我自己使用uni-app 已经实现了内容的显示或者隐藏,因此可以确定v-show 是可以作用微信小程序的
  2. 微信的组件显示或者不显示,实际上是根据组件的 hidden 属性来决定的,如果为true则不显示,false则显示
  3. 看逻辑代码,也是正确的使用了v-show,而且在其他页面也是起作用的

问题突破口

  1. 发现代码的 v-show 是写在组件上的,而不是 uni-app 基本组件上
  2. 因此我猜测 v-show 只适用基本组件
  3. 于是我在组件外面添加了一个 <view> 标签,然后v-show 作用到 <view> 标签上,结果正常的显示
  4. 通过调试工具,发现uni-app 会将v-show 的组件添加hidden属性,而在组件中添加hidden属性,不会起作用

结论

  1. v-show 是动态的给组件添加hidden属性,如果为true则不显示,false则显示
  2. 给自定义组件添加hidden属性,则不会显示或隐藏

代码验证

<view>
  <text>pages/wccomp/wxComponentPage.wxml</text>
</view>
<view>
  <view hidden="true">
    测试hidden 不显示
  </view>
  <first-component id="mycomp" hidden='{{hideComp}}'/>
  <first-component id="mycomp" hidden='true'/>
  <first-component id="mycomp" />
</view>

在这里插入图片描述

  1. hidden为true,基本组件不显示
  2. hidden为true,自定义组件显示
  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值