el-tabs标签页,
标签,用:is
切换加载
动态切换标签页并显示不同组件内容
//.vue单文件
<template>
<div :class="bemCss('tabs')">
<el-tabs v-model="activeName" @tab-click="handleClick">
<el-tab-pane
v-for="(item, index) in this.tabsData"
:key="index"
:label="item.labelName"
:name="item.tabName"
v-if="item.show"
>
<keep-alive>
<component :is="currentTabComponent"></component>
</keep-alive>
</el-tab-pane>
</el-tabs>
</div>
</template>
<script>
import create from "../../core/create";
export default create({
name: "tabs",
props: {
option: {
type: Object,
default: () => {
return {
};
},
},
},
computed: {
tabsData: function () {
return this.option.tabsData || [];
},
},
data() {
return {
currentTabComponent: this.option.currentTabComponent||"",
activeName: this.option.activeName || "",
};
},
methods: {
handleClick(tab) {
this.currentTabComponent=tab.paneName;
},
},
});
</script>
<style scoped lang="scss">
$theme-color: #ff0000;
$height: 50px;
.hxvue-tabs {
&__tabs {
position: absolute;
>>> .el-tabs {
&__item {
font-size: 16px;
font-family: Segoe UI, Segoe UI-Bold;
font-weight: 800;
color: #909399;
&.is-active {
color: $theme-color;
}
&:hover {
color: $theme-color;
}
}
&__header {
height: $height;
}
&__active-bar {
background-color: $theme-color;
height: 3px;
}
&__nav {
height: $height;
&-wrap {
height: $height;
&::after {
height: 0;
}
}
&-scroll {
height: $height;
}
}
}
}
}
</style>
//使用代码
<script>
//开始生成测试数据
const demoData = [];
const demoDataNum = 5;
let active = "";
const tabName = ["tab-one", "tab-two", "tab-three", "tab-four", "tab-five"];
for (let i = 0; i < demoDataNum; i++) {
demoData.push({
labelName: Mock.mock("@ctitle(2, 5)"),
tabName: tabName[i],
show: Mock.mock({
"boolean|1": true,
}).boolean,
});
}
for (let i = 0; i < demoDataNum; i++) {
if (demoData[i].show === true) {
active = demoData[i].tabName;
break;
}
}
Vue.component("tab-one", {
template: "This is tab one.",
});
Vue.component("tab-two", {
template: "This is tab two.",
});
Vue.component("tab-three", {
template: "This is tab three.",
});
Vue.component("tab-four", {
template: "This is tab four.",
});
Vue.component("tab-five", {
template: "This is tab five.",
});
new Vue({
el: "#app",
data() {
return {
option: {
currentTabComponent:active,
activeName: active,
cardSpan: 4,
tabsData: demoData,
},
};
},
methods: {
},
});
</script>
@tab-click="handleClick"
这个是el-tabs官方给出的切换标签页使用的方法
:name="item.tabName"
绑定每个el-tab-pane
的name
<keep-alive>
<component :is="currentTabComponent"></component>
</keep-alive>
动态加载组件,这个在vue.js官方文档中可以找到
handleClick(tab) {
this.currentTabComponent=tab.paneName;
},
通过在控制台输出tab我们可以看到,tab中的paneName属性值就和我们绑定的tabName是同一个值,所以用这个来确定当前加载的组件是什么,让tabName和组件名称相同就可以实现组件的动态切换了,只需要在使用的时候import你要用的页面组件就好了
=========================================================
以上代码在组件开发框架下开发,所以直接拿来使用的话需要做修改,建议看懂了之后再参考编写