vue+iview标签页切换时刷新

1、在TabPane增加name
2、在自定义页面增加ref
3、在Tabs增加click方法currentTabChanged,调用子页面的查询/刷新方法

<template>
	<div id="aaa" style="height: max-content">
		<Tabs :animated="false" active-key="index" @on-click="currentTabChanged" style="background-color: #ffffff;width: auto;height: auto">
			<TabPane label="XX管理" key="index" name="index">
				<view-index ref="index" ></view-index>
			</TabPane>
			<TabPane label="导入" key="import" name="import">
				<view-import ></view-import>
			</TabPane>
		</Tabs>
	</div>
</template>
<script>
	import ViewIndex from './index.vue'
	import ViewImport from './import.vue'

	export default {
		data() {
			return {
				tabName:null
			}
		},
		components: {
			ViewIndex,ViewImport
		},
		methods: {
			currentTabChanged(name){
				//防止多次点击已显示标签页重复刷新问题
				if (name != this.tabName) {
					this.tabName=name
					if (this.tabName == 'index') {
						this.$refs.index.onSubmit()
					}
				}
			}
		},
		mounted() {
		}
	}
</script>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是实现tabs选项卡切换展现各自树的面的步骤: 1. 在Vue3中定义两个组件,一个是包含选项卡的父组件,另一个是选项卡面板对应的子组件。 2. 在父组件中使用`el-tabs`和`el-tab-pane`组件实现选项卡,并将每个选项卡面板对应的子组件包含在`el-tab-pane`组件中。 ``` <template> <el-tabs v-model="activeTab"> <el-tab-pane label="Tab 1" name="1"> <tree-1 /> </el-tab-pane> <el-tab-pane label="Tab 2" name="2"> <tree-2 /> </el-tab-pane> </el-tabs> </template> <script> import Tree1 from './Tree1.vue' import Tree2 from './Tree2.vue' export default { components: { Tree1, Tree2 }, data() { return { activeTab: '1' } } } </script> ``` 3. 在每个子组件中分别实现对应的树形结构,并在`mounted`钩子函数中初始化树形结构。 ``` <template> <div class="tree"> <el-tree :data="treeData" :props="treeProps" :default-expanded-keys="['1']" node-key="id" /> </div> </template> <script> export default { data() { return { treeData: [ { id: 1, label: 'Node 1', children: [ { id: 2, label: 'Node 1-1' }, { id: 3, label: 'Node 1-2' } ] } ], treeProps: { children: 'children', label: 'label' } } }, mounted() { // 初始化树形结构 } } </script> ``` 4. 在父组件中使用`keep-alive`组件包含每个子组件,这样在切换选项卡,之前打开的选项卡对应的子组件的状态就能被保留下来。 ``` <template> <el-tabs v-model="activeTab"> <el-tab-pane label="Tab 1" name="1"> <keep-alive> <tree-1 /> </keep-alive> </el-tab-pane> <el-tab-pane label="Tab 2" name="2"> <keep-alive> <tree-2 /> </keep-alive> </el-tab-pane> </el-tabs> </template> ``` 以上就是实现tabs选项卡切换展现各自树的面的步骤。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值