Demo
<template>
<div class="demo-container">
<shapeContainer :config="config">
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
</shapeContainer>
</div>
</template>
<script setup>
import {ref, onMounted, onUnmounted} from 'vue';
const config = ref({
shapes: ['line', 'circle', 'arc', 'square', 'bezier'],
shapeIndex: 0,
loopElements: true
});
const intervalTimer = ref(null);
onMounted(() => {
intervalTimer.value = setInterval(() => {
config.value.shapeIndex = (config.value.shapeIndex + 1) % config.value.shapes.length;
config.value.shape = config.value.shapes[config.value.shapeIndex];
}, 4000);
});
onUnmounted(() => {
clearInterval(intervalTimer.value);
});
</script>