12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- <template>
- <div style="margin-bottom: 20px">
- <el-button size="small" @click="addTab(editableTabsValue)">
- add tab
- </el-button>
- </div>
- <el-tabs
- v-model="editableTabsValue"
- type="card"
- class="demo-tabs"
- closable
- @tab-remove="removeTab"
- >
- <el-tab-pane
- v-for="item in editableTabs"
- :key="item.name"
- :label="item.title"
- :name="item.name"
- >
- {{ item.content }}
- </el-tab-pane>
- </el-tabs>
- </template>
- <script lang="ts" setup>
- import { ref } from 'vue'
- let tabIndex = 2
- const editableTabsValue = ref('2')
- const editableTabs = ref([
- {
- title: 'Tab 1',
- name: '1',
- content: 'Tab 1 content',
- },
- {
- title: 'Tab 2',
- name: '2',
- content: 'Tab 2 content',
- },
- ])
- const addTab = (targetName: string) => {
- const newTabName = `${++tabIndex}`
- editableTabs.value.push({
- title: 'New Tab',
- name: newTabName,
- content: 'New Tab content',
- })
- editableTabsValue.value = newTabName
- }
- const removeTab = (targetName: string) => {
- const tabs = editableTabs.value
- let activeName = editableTabsValue.value
- if (activeName === targetName) {
- tabs.forEach((tab, index) => {
- if (tab.name === targetName) {
- const nextTab = tabs[index + 1] || tabs[index - 1]
- if (nextTab) {
- activeName = nextTab.name
- }
- }
- })
- }
- editableTabsValue.value = activeName
- editableTabs.value = tabs.filter((tab) => tab.name !== targetName)
- }
- </script>
- <style>
- .demo-tabs > .el-tabs__content {
- padding: 32px;
- color: #6b778c;
- font-size: 32px;
- font-weight: 600;
- }
- </style>
|