Vue.js 关于页面加载完成后执行一个方法的问题

Web 同时被 3 个专栏收录
3 篇文章 0 订阅
4 篇文章 0 订阅
7 篇文章 0 订阅

首先我们会想着在mounted或者created里面加入想要执行的方法,但是有的时候会遇到在你执行这个方法的时候,页面还并没有被渲染完成,所以就会出现这个方法在匹配页面标签报错的情况。

解决思路:

1.通过子页面调用父页面的方法,因为在子页面开始渲染的时候,你的父页面肯定是已经渲染好了的,前提这里的方法中是去找寻父页面的标签。

2.直接在本页面监视一个参数,发现参数被初始化了,说明页面也已经加载完成,因为你的页面用到了这个参数。

 

方法1案例:tab页里的子页面如果没有内容就隐藏

父页面代码

<el-tabs v-model="initTab" type="card">
  <el-tab-pane label="1信息" name="tab1">
    1
  </el-tab-pane>
  <el-tab-pane label="2报告" name="tab2">
    2
  </el-tab-pane>
  <el-tab-pane label="3信息" name="tab3">
    3
  </el-tab-pane>
  <el-tab-pane label="4信息" name="tab4">
    <ziyemian-group @tabShow="tabShow" title="4信息" v-if="detailInfo">
    </ziyemian-group>

  </el-tab-pane>
  <el-tab-pane label="5信息" name="tab5">
    5
  </el-tab-pane>
  <el-tab-pane label="其它信息" name="tab6">
    6
  </el-tab-pane>
</el-tabs>

import ZiyemianGroup from './ZiyemianGroup.vue'
components: {
  ZiyemianGroup
},
data () {
    return {
        detailInfo: {},
        initTab:‘tab1’
    }
}
methods: {
  tabShow: (data) => {
    document.getElementsByClassName('el-tabs__item').item(4).style.display = data
  },
}

然后是ZiyemianGroup.vue的代码,这里主要就是方法调用,页面自己搞定

data () {
  return {
    list: []
  }
},
mounted () {
  this.init()
},
methods: {
  init() {
    if (list.length > 0) {
        this.$emit('tabShow', 'inline')
    } else {
        this.$emit('tabShow', 'none')
    }
  )
}

list是子页面的内容,这样如果子页面没有内容就可以隐藏掉了

 

方法2案例:我这边需要tab页隐藏

<el-tabs v-model="initTab" type="card">
  <el-tab-pane label="1信息" name="tab1">
    1
  </el-tab-pane>
  <el-tab-pane label="2报告" name="tab2">
    2
  </el-tab-pane>
  <el-tab-pane label="3信息" name="tab3">
    3
  </el-tab-pane>
  <el-tab-pane label="4信息" name="tab4">
    <ziyemian-group title="4信息" v-if="detailInfo">
    </ziyemian-group>

  </el-tab-pane>
  <el-tab-pane label="5信息" name="tab5">
    5
  </el-tab-pane>
  <el-tab-pane label="其它信息" name="tab6">
    6
  </el-tab-pane>
</el-tabs>

import ZiyemianGroup from './ZiyemianGroup.vue'
components: {
  ZiyemianGroup
},
data () {
    return {
        detailInfo: {},
        initTab:‘tab1’
    }
}
watch: {
  detailInfo: function () {
    this.$nextTick(function () {
      this.tabShow()
    })
  }
},
methods: {
    tabShow () {
        document.getElementsByClassName('el-tabs__item').item(6).style.display = 'none' // 隐藏tab6
    }
}

nextTick方法,意思是在下次 DOM 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的 DOM。

隐藏tab的方法我用了原生js,因为vue生成后的页面和写的vue页面有所差别,所以我直接用了最笨的方法进行匹配。

  • 2
    点赞
  • 1
    评论
  • 7
    收藏
  • 打赏
    打赏
  • 扫一扫,分享海报

©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页

打赏作者

ITKouSyou

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

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值