|
1 | 1 | <template>
|
2 | 2 | <div class="veui-tabs" :ui="ui">
|
3 |
| - <div class="veui-tabs-menu" ref="menu"> |
| 3 | + <div class="veui-tabs-menu" ref="menu" role="tablist"> |
4 | 4 | <div class="veui-tabs-list" :class="{'veui-tabs-list-empty': items.length === 0}" ref="resizeContainer" v-resize="(e) => resizeHandler(e)">
|
5 | 5 | <div class="veui-tabs-list-resizer">
|
6 | 6 | <template v-for="(tab, index) in items">
|
7 |
| - <div :key="tab.name" class="veui-tabs-item" :ref="`tab-${tab.name}`" :class="{ |
8 |
| - 'veui-tabs-item-disabled': tab.disabled, |
9 |
| - 'veui-tabs-item-active': index === localIndex |
10 |
| - }"> |
| 7 | + <div |
| 8 | + :key="tab.name" |
| 9 | + :ref="`tab-${tab.name}`" |
| 10 | + :class="{ |
| 11 | + 'veui-tabs-item': true, |
| 12 | + 'veui-tabs-item-disabled': tab.disabled, |
| 13 | + 'veui-tabs-item-active': index === localIndex |
| 14 | + }"> |
11 | 15 | <slot name="tab-item" v-bind="tab" :index="index">
|
12 |
| - <veui-link v-if="tab.to" class="veui-tabs-item-label" :to="tab.to" :native="tab.native">{{ tab.label }}</veui-link> |
13 |
| - <button v-else class="veui-tabs-item-label" type="button" @click="!tab.disabled && setActive({index})">{{ tab.label }}</button> |
14 |
| - <button type="button" class="veui-tabs-item-remove" |
15 |
| - @click="$emit('remove', tab)"> |
16 |
| - <slot name="tab-item-extra" v-bind="tab"> |
17 |
| - <icon :name="icons.remove" |
18 |
| - v-if="tab.removable"></icon> |
19 |
| - </slot> |
| 16 | + <veui-link |
| 17 | + v-if="tab.to" |
| 18 | + class="veui-tabs-item-label" |
| 19 | + v-bind="ariaAttrs[index]" |
| 20 | + :to="tab.to" |
| 21 | + :native="tab.native"> |
| 22 | + {{ tab.label }} |
| 23 | + </veui-link> |
| 24 | + <button |
| 25 | + v-else |
| 26 | + class="veui-tabs-item-label" |
| 27 | + v-bind="ariaAttrs[index]" |
| 28 | + type="button" |
| 29 | + @click="!tab.disabled && setActive({index})"> |
| 30 | + {{ tab.label }} |
20 | 31 | </button>
|
| 32 | + <slot name="tab-item-extra" v-bind="tab"> |
| 33 | + <button v-if="tab.removable" type="button" class="veui-tabs-item-remove" |
| 34 | + aria-label="删除" |
| 35 | + @click="$emit('remove', tab)"> |
| 36 | + <icon :name="icons.remove"/> |
| 37 | + </button> |
| 38 | + </slot> |
21 | 39 | </slot>
|
22 | 40 | </div>
|
23 | 41 | </template>
|
|
29 | 47 | :class="{'veui-tabs-extra-overflow': menuOverflow}">
|
30 | 48 | <button type="button" v-if="addable"
|
31 | 49 | class="veui-tabs-operator"
|
| 50 | + aria-label="添加" |
32 | 51 | @click="$emit('add')">
|
33 |
| - <icon :name="icons.add"></icon><slot name="tabs-extra-text"><span>添加TAB</span></slot> |
| 52 | + <icon :name="icons.add"></icon><slot name="tabs-extra-text"><span>添加 Tab</span></slot> |
34 | 53 | </button>
|
35 |
| - <div class="veui-tabs-scroller" v-if="menuOverflow" ref="scroller"> |
| 54 | + <div class="veui-tabs-scroller" v-if="menuOverflow" ref="scroller" aria-hidden="true"> |
36 | 55 | <button type="button" class="veui-tabs-scroller-left" @click="scroll('left')"><icon :name="icons.prev"></icon></button>
|
37 | 56 | <button type="button" class="veui-tabs-scroller-right" @click="scroll('right')"><icon :name="icons.next"></icon></button>
|
38 | 57 | </div>
|
@@ -93,6 +112,16 @@ export default {
|
93 | 112 | },
|
94 | 113 | tabNames () {
|
95 | 114 | return this.items.map(({ name }) => name)
|
| 115 | + }, |
| 116 | + ariaAttrs () { |
| 117 | + return this.items.map((tab, index) => { |
| 118 | + return { |
| 119 | + role: 'tab', |
| 120 | + 'aria-selected': String(index === this.localIndex), |
| 121 | + 'aria-setsize': this.items.length, |
| 122 | + 'aria-posinset': index + 1 |
| 123 | + } |
| 124 | + }) |
96 | 125 | }
|
97 | 126 | },
|
98 | 127 | methods: {
|
|
0 commit comments