58 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
<template>
 | 
						|
    <div :class="`spin-${type}`">
 | 
						|
        <div v-if="type === 'ring'"></div>
 | 
						|
        <div v-if="type === 'ring'"></div>
 | 
						|
        <div v-if="type === 'ring'"></div>
 | 
						|
        <div v-if="type === 'ring'"></div>
 | 
						|
    </div>
 | 
						|
</template>
 | 
						|
 | 
						|
<script>
 | 
						|
export default {
 | 
						|
    props: {
 | 
						|
        type: {
 | 
						|
            type: String,
 | 
						|
            default: () => 'ring',
 | 
						|
        },
 | 
						|
    },
 | 
						|
};
 | 
						|
</script>
 | 
						|
 | 
						|
<style>
 | 
						|
.spin-ring {
 | 
						|
    display: inline-block;
 | 
						|
    position: relative;
 | 
						|
}
 | 
						|
.spin-ring div {
 | 
						|
    box-sizing: border-box;
 | 
						|
    display: block;
 | 
						|
    position: absolute;
 | 
						|
    width: 100%;
 | 
						|
    height: 100%;
 | 
						|
    border: 3px solid #fff;
 | 
						|
    border-radius: 50%;
 | 
						|
    animation: ring 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
 | 
						|
    border-top-color: inherit;
 | 
						|
    border-right-color: transparent;
 | 
						|
    border-bottom-color: transparent;
 | 
						|
    border-left-color: transparent;
 | 
						|
}
 | 
						|
.spin-ring div:nth-child(1) {
 | 
						|
    animation-delay: -0.45s;
 | 
						|
}
 | 
						|
.spin-ring div:nth-child(2) {
 | 
						|
    animation-delay: -0.3s;
 | 
						|
}
 | 
						|
.spin-ring div:nth-child(3) {
 | 
						|
    animation-delay: -0.15s;
 | 
						|
}
 | 
						|
@keyframes ring {
 | 
						|
    0% {
 | 
						|
        transform: rotate(0deg);
 | 
						|
    }
 | 
						|
    100% {
 | 
						|
        transform: rotate(360deg);
 | 
						|
    }
 | 
						|
}
 | 
						|
</style>
 |