<template>
<div>
点击画布创建一个圆形。
<a href=".">重新加载页面</a>。圆形应当会保持在这里。
<v-stage
ref="stage"
:config="stageSize"
@click="handleClick"
>
<v-layer ref="layer">
<v-circle
v-for="item in list"
:key="item.id"
:config="item"
/>
</v-layer>
</v-stage>
</div>
</template>
<script setup>
import { ref, onMounted } from 'vue';
const stageSize = {
width: window.innerWidth,
height: window.innerHeight
};
const list = ref([{ x: 100, y: 100, radius: 50, fill: 'blue' }]);
const handleClick = (evt) => {
const stage = evt.target.getStage();
const pos = stage.getPointerPosition();
list.value.push({
radius: 50,
fill: 'red',
...pos
});
save();
};
const load = () => {
const data = localStorage.getItem('storage');
if (data) list.value = JSON.parse(data);
};
const save = () => {
localStorage.setItem('storage', JSON.stringify(list.value));
};
onMounted(() => {
load();
});
</script>