Merge pull request #2833 from Xotic750/button_tabindex
Feature: Button tab navigation
This commit is contained in:
commit
4ba1df8187
2 changed files with 22 additions and 3 deletions
|
@ -1,5 +1,11 @@
|
||||||
<template>
|
<template>
|
||||||
<button :type="htmlType" :class="classes" :disabled="disabled" @click="handleClick">
|
<button
|
||||||
|
:type="htmlType"
|
||||||
|
:class="classes"
|
||||||
|
:disabled="disabled"
|
||||||
|
@blur="handleBlur"
|
||||||
|
@click="handleClick"
|
||||||
|
@focus="handleFocus">
|
||||||
<Icon class="ivu-load-loop" type="load-c" v-if="loading"></Icon>
|
<Icon class="ivu-load-loop" type="load-c" v-if="loading"></Icon>
|
||||||
<Icon :type="icon" v-if="icon && !loading"></Icon>
|
<Icon :type="icon" v-if="icon && !loading"></Icon>
|
||||||
<span v-if="showSlot" ref="slot"><slot></slot></span>
|
<span v-if="showSlot" ref="slot"><slot></slot></span>
|
||||||
|
@ -46,6 +52,7 @@
|
||||||
},
|
},
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
|
isFocused: false,
|
||||||
showSlot: true
|
showSlot: true
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
@ -59,15 +66,22 @@
|
||||||
[`${prefixCls}-${this.shape}`]: !!this.shape,
|
[`${prefixCls}-${this.shape}`]: !!this.shape,
|
||||||
[`${prefixCls}-${this.size}`]: !!this.size,
|
[`${prefixCls}-${this.size}`]: !!this.size,
|
||||||
[`${prefixCls}-loading`]: this.loading != null && this.loading,
|
[`${prefixCls}-loading`]: this.loading != null && this.loading,
|
||||||
[`${prefixCls}-icon-only`]: !this.showSlot && (!!this.icon || this.loading)
|
[`${prefixCls}-icon-only`]: !this.showSlot && (!!this.icon || this.loading),
|
||||||
|
[`${prefixCls}-focused`]: this.isFocused
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
handleBlur () {
|
||||||
|
this.isFocused = false;
|
||||||
|
},
|
||||||
handleClick (event) {
|
handleClick (event) {
|
||||||
this.$emit('click', event);
|
this.$emit('click', event);
|
||||||
}
|
},
|
||||||
|
handleFocus () {
|
||||||
|
this.isFocused = true;
|
||||||
|
},
|
||||||
},
|
},
|
||||||
mounted () {
|
mounted () {
|
||||||
this.showSlot = this.$slots.default !== undefined;
|
this.showSlot = this.$slots.default !== undefined;
|
||||||
|
|
|
@ -4,6 +4,11 @@
|
||||||
.btn;
|
.btn;
|
||||||
.btn-default;
|
.btn-default;
|
||||||
|
|
||||||
|
&.@{btn-prefix-cls}-focused {
|
||||||
|
box-shadow: 0 0 2px @link-hover-color, 0 0 2px @link-hover-color, 0 0 2px @link-hover-color, 0 0 2px @link-hover-color;
|
||||||
|
z-index: 1;
|
||||||
|
}
|
||||||
|
|
||||||
&-long{
|
&-long{
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue