mirror of
https://gitee.com/element-plus/element-plus.git
synced 2024-12-04 04:08:34 +08:00
feat(tabs): optimize code
This commit is contained in:
parent
a2f03be92a
commit
72daa4359d
@ -24,7 +24,7 @@ export default defineComponent({
|
||||
const instance = getCurrentInstance()
|
||||
|
||||
const getBarStyle = () => {
|
||||
let style: CSSStyleDeclaration = {} as CSSStyleDeclaration
|
||||
let style = {} as CSSStyleDeclaration
|
||||
let offset = 0
|
||||
let tabSize = 0
|
||||
|
||||
|
@ -1,6 +1,8 @@
|
||||
<script lang='ts'>
|
||||
import { h, defineComponent, ref, inject, computed, onUpdated, onMounted, onBeforeUnmount } from 'vue'
|
||||
import { addResizeListener, removeResizeListener } from '@element-plus/utils/resize-event'
|
||||
import { eventKeys } from '@element-plus/utils/aria'
|
||||
import { on, off } from '@element-plus/utils/dom'
|
||||
import TabBar from './tab-bar.vue'
|
||||
import { NOOP, capitalize } from '@vue/shared'
|
||||
|
||||
@ -22,11 +24,11 @@ export default defineComponent({
|
||||
},
|
||||
editable: Boolean,
|
||||
onTabClick: {
|
||||
type: Function,
|
||||
type: Function as PropType<(tab: ComponentInternalInstance, tabName: string, ev: Event) => void>,
|
||||
default: NOOP,
|
||||
},
|
||||
onTabRemove: {
|
||||
type: Function,
|
||||
type: Function as PropType<(tab: ComponentInternalInstance, ev: Event) => void>,
|
||||
default: NOOP,
|
||||
},
|
||||
type: {
|
||||
@ -147,13 +149,15 @@ export default defineComponent({
|
||||
const keyCode = e.keyCode
|
||||
let nextIndex
|
||||
let currentIndex, tabList
|
||||
if ([37, 38, 39, 40].indexOf(keyCode) !== -1) { // 左右上下键更换tab
|
||||
|
||||
const { up, down, left, right } = eventKeys
|
||||
if ([up, down, left, right].indexOf(keyCode) !== -1) { // 左右上下键更换tab
|
||||
tabList = e.currentTarget.querySelectorAll('[role=tab]')
|
||||
currentIndex = Array.prototype.indexOf.call(tabList, e.target)
|
||||
} else {
|
||||
return
|
||||
}
|
||||
if (keyCode === 37 || keyCode === 38) { // left
|
||||
if (keyCode === left || keyCode === up) { // left
|
||||
if (currentIndex === 0) { // first
|
||||
nextIndex = tabList.length - 1
|
||||
} else {
|
||||
@ -208,9 +212,9 @@ export default defineComponent({
|
||||
|
||||
onMounted(() => {
|
||||
addResizeListener(el$.value, update)
|
||||
document.addEventListener('visibilitychange', visibilityChangeHandler)
|
||||
window.addEventListener('blur', windowBlurHandler)
|
||||
window.addEventListener('focus', windowFocusHandler)
|
||||
on(document, 'visibilitychange', visibilityChangeHandler)
|
||||
on(window, 'blur', windowBlurHandler)
|
||||
on(window, 'focus', windowFocusHandler)
|
||||
setTimeout(() => {
|
||||
scrollToActiveTab()
|
||||
}, 0)
|
||||
@ -220,9 +224,9 @@ export default defineComponent({
|
||||
if(el$.value) {
|
||||
removeResizeListener(el$.value, update)
|
||||
}
|
||||
document.removeEventListener('visibilitychange', visibilityChangeHandler)
|
||||
window.removeEventListener('blur', windowBlurHandler)
|
||||
window.removeEventListener('focus', windowFocusHandler)
|
||||
off(document, 'visibilitychange', visibilityChangeHandler)
|
||||
off(window, 'blur', windowBlurHandler)
|
||||
off(window, 'focus', windowFocusHandler)
|
||||
})
|
||||
|
||||
return {
|
||||
|
@ -20,10 +20,6 @@ export default defineComponent({
|
||||
type: String,
|
||||
default: '',
|
||||
},
|
||||
labelContent: {
|
||||
type: Function,
|
||||
default: null,
|
||||
},
|
||||
name: {
|
||||
type: String,
|
||||
default: '',
|
||||
|
@ -29,7 +29,7 @@ export default defineComponent({
|
||||
default: 'top',
|
||||
},
|
||||
beforeLeave: {
|
||||
type: Function,
|
||||
type: Function as PropType<(newTabName: string, oldTabName: string) => void>,
|
||||
default: null,
|
||||
},
|
||||
stretch: Boolean,
|
||||
@ -61,7 +61,8 @@ export default defineComponent({
|
||||
})
|
||||
|
||||
const getPaneInstanceFromSlot = (vnode, paneInstanceList = []) => {
|
||||
[...(vnode.children || [])].forEach(node => {
|
||||
|
||||
Array.from(vnode.children || []).forEach(node => {
|
||||
let type = node.type
|
||||
type = type.name || type
|
||||
if (type === 'ElTabPane' && node.component) {
|
||||
@ -77,7 +78,7 @@ export default defineComponent({
|
||||
if(ctx.slots.default) {
|
||||
const children = instance.subTree.children
|
||||
|
||||
const content = [...children].find(({ props }) => {
|
||||
const content = Array.from(children).find(({ props }) => {
|
||||
return props.class === 'el-tabs__content'
|
||||
})
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user