css 点击显示并移动元素,再次点击移回元素并消失

点击前

点击一次 先显示出来,并移动到左侧

再次点击,再移动回来,并消失

整体代码如下:

js 复制代码
<template>
  <div id="myElement" class="box" @click="click_me">
    点击我
  </div>
  <div class="sub" :class="{'move-left': moveLeft, 'move-right': moveRight, 'hidden': isHidden}">
  </div>
</template>

<script setup>
import { ref } from "vue";

const moveLeft = ref(false);
const moveRight = ref(false);
const isHidden = ref(true); // 初始状态为隐藏

const click_me = () => {
  if (isHidden.value && !moveLeft.value && !moveRight.value) {
    // 第一次点击:显示并向左移动
    isHidden.value = false;
    setTimeout(() => {
      moveLeft.value = true;
    }, 50);
  } else if (moveLeft.value && !moveRight.value) {
    // 第二次点击:向右移动回来
    moveLeft.value = false;
    moveRight.value = true;

    // 等待移动完成后消失
    setTimeout(() => {
      isHidden.value = true;
      moveRight.value = false;
    }, 500);
  }
};
</script>

<style scoped>
.box {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100px;
  height: 100px;
  overflow: hidden;
  text-align: center;
  background-color: pink;
  cursor: pointer;
}

.sub {
  position: fixed;
  top: 100px;
  left: calc(50% - 100px); /* 初始居中位置 */
  width: 200px;
  height: 200px;
  background-color: skyblue;
  transition: left 0.5s ease, opacity 0.3s ease, visibility 0.3s ease;
}

.move-left {
  left: calc(50% - 400px); /* 向左移动300px:从 50%-100px 到 50%-400px */
}

.move-right {
  left: calc(50% - 100px); /* 向右移动回初始居中位置 */
}

.hidden {
  opacity: 0;
  visibility: hidden;
}
</style>
相关推荐
道友可好23 分钟前
OpenSpec:轻到起飞的 AI 编程规范层
前端·人工智能·后端
kyriewen31 分钟前
我招了一个“Prompt工程师”来写前端,结果项目差点崩了
前端·javascript·面试
jingling55535 分钟前
Flutter | 商城项目完整实战
前端·flutter·前端框架
IT_陈寒36 分钟前
React状态管理这个坑,我爬了整整三天才出来
前端·人工智能·后端
小新1101 小时前
从零开始 Vue.js
前端·javascript·vue.js
naildingding1 小时前
Vue基础核心
前端·vue.js
弱鸡前端1 小时前
纯前端实现pdf从生成到下载
前端
明月_清风1 小时前
TanStack + Cloudflare 边缘实战:从 0 到 1 构建全栈应用
前端·全栈
东风破_1 小时前
你天天用的 Python dict,90% 的人没搞懂这三个坑
前端
Delicate1 小时前
JavaScript的“变脸”艺术:类型转换戏法大揭秘
javascript