[new feature] Loading: add circular type (#618)

This commit is contained in:
neverland 2018-02-07 16:35:24 +08:00 committed by GitHub
parent 6e00edac2d
commit 866aff9c45
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 121 additions and 54 deletions

View File

@ -14,6 +14,11 @@
<van-loading type="spinner" color="black" />
<van-loading type="spinner" color="white" />
</demo-block>
<demo-block :title="$t('title4')">
<van-loading type="circular" color="black" />
<van-loading type="circular" color="white" />
</demo-block>
</demo-section>
</template>
@ -23,12 +28,14 @@ export default {
'zh-CN': {
title1: '单色圆环',
title2: '渐变色圆环',
title3: 'Spinner'
title3: 'Spinner',
title4: 'Circular'
},
'en-US': {
title1: 'Solid Circle',
title2: 'Gradient Circle',
title3: 'Spinner'
title3: 'Spinner',
title4: 'Circular'
}
}
};
@ -38,7 +45,13 @@ export default {
.demo-loading {
.van-loading {
display: inline-block;
margin: 10px 0 10px 20px;
margin: 5px 0 5px 20px;
}
.van-loading--white {
padding: 10px;
border-radius: 3px;
background-color: rgba(0, 0, 0, .5);
}
}
</style>

View File

@ -30,6 +30,13 @@ Vue.use(Loading);
<van-loading type="spinner" color="white" />
```
#### Circular
```html
<van-loading type="circular" color="black" />
<van-loading type="circular" color="white" />
```
### API
| Attribute | Description | Type | Default | Accepted Values |

View File

@ -30,6 +30,13 @@ Vue.use(Loading);
<van-loading type="spinner" color="white" />
```
#### Circular
```html
<van-loading type="circular" color="black" />
<van-loading type="circular" color="white" />
```
### API
| 参数 | 说明 | 类型 | 默认值 | 可选值 |

View File

@ -1,7 +1,10 @@
<template>
<div class="van-loading" :class="['van-loading--' + type, 'van-loading--' + color]">
<span class="van-loading__spinner" :class="['van-loading__spinner--' + type, 'van-loading__spinner--' + color]">
<i v-if="type === 'spinner'" v-for="item in 12" />
<span class="van-loading__spinner" :class="'van-loading__spinner--' + type">
<i v-for="item in (type === 'spinner' ? 12 : 0)" />
<svg v-if="type === 'circular'" class="van-loading__circular" viewBox="25 25 50 50">
<circle cx="50" cy="50" r="20" fill="none"/>
</svg>
</span>
</div>
</template>

View File

@ -15,8 +15,8 @@
&__layer {
fill: none;
stroke-dasharray: 3140px;
stroke-dashoffset: 3140px;
stroke-dasharray: 3140;
stroke-dashoffset: 3140;
transform: rotate(90deg);
transform-origin: 530px 530px;
}

View File

@ -28,6 +28,15 @@
}
}
@keyframes van-rotate {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
.van-fade {
&-enter-active {
animation: .3s van-fade-in;

View File

@ -1,70 +1,38 @@
@import './common/var.css';
@keyframes van-loading {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
.van-loading {
width: 30px;
height: 30px;
z-index: 0;
font-size: 0;
line-height: 0;
z-index: 0;
position: relative;
vertical-align: middle;
&--circle {
width: 16px;
height: 16px;
vertical-align: middle;
}
&--gradient-circle,
&--spinner {
width: 30px;
height: 30px;
}
&__spinner {
z-index: -1;
width: 100%;
height: 100%;
position: relative;
z-index: -1;
display: inline-block;
animation: van-loading 0.8s linear infinite;
box-sizing: border-box;
animation: van-rotate 0.8s linear infinite;
&--circle {
border-radius: 100%;
border: 3px solid transparent;
box-sizing: border-box;
&.van-loading__spinner--black {
border-color: $gray;
border-top-color: $gray-darker;
}
&.van-loading__spinner--white {
border-color: rgba(0, 0, 0, .1);
border-top-color: rgba(255, 255, 255, .7);
}
}
&--gradient-circle {
background-size: contain;
&.van-loading__spinner--black {
background-image: url('');
}
&.van-loading__spinner--white {
background-image: url('');
}
}
&--spinner {
color: $gray;
animation-timing-function: steps(12);
i {
@ -84,11 +52,75 @@
background-color: currentColor;
}
}
&.van-loading__spinner--white {
color: #fff;
}
}
&--circular {
animation-duration: 2s;
}
}
&__circular {
width: 100%;
height: 100%;
circle {
stroke-width: 3;
stroke-linecap: round;
animation: van-circular 1.5s ease-in-out infinite;
}
}
&--black {
.van-loading__spinner--circle {
border-color: $gray;
border-top-color: $gray-darker;
}
.van-loading__spinner--gradient-circle {
background-image: url('https://b.yzcdn.cn/vant/gradient-circle-black.png');
}
.van-loading__spinner--spinner {
color: $gray;
}
.van-loading__circular circle {
stroke: $gray;
}
}
&--white {
.van-loading__spinner--circle {
border-color: rgba(0, 0, 0, .1);
border-top-color: rgba(255, 255, 255, .7);
}
.van-loading__spinner--gradient-circle {
background-image: url('https://b.yzcdn.cn/vant/gradient-circle-white.png');
}
.van-loading__spinner--spinner {
color: #fff;
}
.van-loading__circular circle {
stroke: $white;
}
}
}
@keyframes van-circular {
0% {
stroke-dasharray: 1, 200;
stroke-dashoffset: 0;
}
50% {
stroke-dasharray: 90, 150;
stroke-dashoffset: -40;
}
100% {
stroke-dasharray: 90, 150;
stroke-dashoffset: -120;
}
}

View File

@ -23,7 +23,6 @@ describe('Loading', () => {
const spinner = wrapper.find('.van-loading__spinner')[0];
expect(spinner.hasClass('van-loading__spinner--gradient-circle')).to.be.true;
expect(spinner.hasClass('van-loading__spinner--black')).to.be.true;
});
it('create gradient-circle white', () => {
@ -36,7 +35,6 @@ describe('Loading', () => {
const spinner = wrapper.find('.van-loading__spinner')[0];
expect(spinner.hasClass('van-loading__spinner--gradient-circle')).to.be.true;
expect(spinner.hasClass('van-loading__spinner--white')).to.be.true;
});
it('create circle black', () => {
@ -49,7 +47,6 @@ describe('Loading', () => {
const spinner = wrapper.find('.van-loading__spinner')[0];
expect(spinner.hasClass('van-loading__spinner--circle')).to.be.true;
expect(spinner.hasClass('van-loading__spinner--black')).to.be.true;
});
it('create circle white', () => {
@ -62,6 +59,5 @@ describe('Loading', () => {
const spinner = wrapper.find('.van-loading__spinner')[0];
expect(spinner.hasClass('van-loading__spinner--circle')).to.be.true;
expect(spinner.hasClass('van-loading__spinner--white')).to.be.true;
});
});