diff --git a/docs/demos/views/loading.vue b/docs/demos/views/loading.vue
index 6b7430075..c4870a2bf 100644
--- a/docs/demos/views/loading.vue
+++ b/docs/demos/views/loading.vue
@@ -14,6 +14,11 @@
+
+
+
+
+
@@ -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);
}
}
diff --git a/docs/markdown/en-US/loading.md b/docs/markdown/en-US/loading.md
index 5ac34a998..326d138e2 100644
--- a/docs/markdown/en-US/loading.md
+++ b/docs/markdown/en-US/loading.md
@@ -30,6 +30,13 @@ Vue.use(Loading);
```
+#### Circular
+
+```html
+
+
+```
+
### API
| Attribute | Description | Type | Default | Accepted Values |
diff --git a/docs/markdown/zh-CN/loading.md b/docs/markdown/zh-CN/loading.md
index 06a3c0667..b2ec4e218 100644
--- a/docs/markdown/zh-CN/loading.md
+++ b/docs/markdown/zh-CN/loading.md
@@ -30,6 +30,13 @@ Vue.use(Loading);
```
+#### Circular
+
+```html
+
+
+```
+
### API
| 参数 | 说明 | 类型 | 默认值 | 可选值 |
diff --git a/packages/loading/index.vue b/packages/loading/index.vue
index f12c0c54c..351a02974 100644
--- a/packages/loading/index.vue
+++ b/packages/loading/index.vue
@@ -1,7 +1,10 @@
-
-
+
+
+
diff --git a/packages/vant-css/src/circle.css b/packages/vant-css/src/circle.css
index 49eb936db..d4c777616 100644
--- a/packages/vant-css/src/circle.css
+++ b/packages/vant-css/src/circle.css
@@ -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;
}
diff --git a/packages/vant-css/src/common/animation.css b/packages/vant-css/src/common/animation.css
index f100d1413..1c1330cf6 100644
--- a/packages/vant-css/src/common/animation.css
+++ b/packages/vant-css/src/common/animation.css
@@ -28,6 +28,15 @@
}
}
+@keyframes van-rotate {
+ from {
+ transform: rotate(0deg);
+ }
+ to {
+ transform: rotate(360deg);
+ }
+}
+
.van-fade {
&-enter-active {
animation: .3s van-fade-in;
diff --git a/packages/vant-css/src/loading.css b/packages/vant-css/src/loading.css
index 0e8258741..3ad8725e2 100644
--- a/packages/vant-css/src/loading.css
+++ b/packages/vant-css/src/loading.css
@@ -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;
}
}
diff --git a/test/unit/specs/loading.spec.js b/test/unit/specs/loading.spec.js
index 0c496be9d..cac5f4e06 100644
--- a/test/unit/specs/loading.spec.js
+++ b/test/unit/specs/loading.spec.js
@@ -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;
});
});