vue组件装载值后无法显示

背景:页面A含子组件B。B为表单组件,内含5个下拉框,下拉选项均由后端接口K返回,所填值由缓存接口M返回。在A页面调接口K和接口M,传值给子组件B。通过打印可知,接口K和接口M的请求和返回均为顺序执行,即先收到接口K的返回,再收到接口M的返回。选项及选项值均已装载,但无法显示。

思路:用v-if强制刷新。

step1:在页面A内引入子组件B时增加v-if

<application-card
    ref="guardianCard"
    :formData="formData"
    :fieldDataList="fieldDataList"
    v-if="isShowAppCard"
></application-card>

注:formData即为传递的值value,fieldDataList内含选项options.

step2:data中初始化值为true(显示该组件)

data() {
    return {
         isShowAppCard: true,
    }
}

step3:在调用接口前将其置为false

created(){
    this.isShowAppCard = false;
    this.setOptions(); // 装载选项
    this.getValue(); // 获取缓存值
}

step4:获取缓存后将其置为true

methods:{
    getValue(){
        ......
        console.log(res)
        this.isShowAppCard = true;
    }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值