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>
相关推荐
橙子家3 小时前
浏览器缓存之【身份与会话管理】:Cookies 和 Private state tokens
前端
To_OC4 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
最新资讯动态4 小时前
HDC 2026 | 对话鲸鸿动能:存量时代,品牌如何夺回营销“主动权”?
前端
最新资讯动态4 小时前
游戏出海,从产品走向体系
前端
最新资讯动态4 小时前
20人团队跑出百万DAU、大厂也来抢量:谁在鸿蒙生态跑出加速度
前端
最新资讯动态5 小时前
千万开发者背后,鸿蒙商业化的B面
前端
爱勇宝6 小时前
AI 时代:智商决定起点,情商决定走多远
前端·ai编程
kyriewen7 小时前
用了半年 Claude Code 后,我尝试关掉它写了一周代码——结果比想象中严重
前端·javascript·ai编程
IT_陈寒7 小时前
Vite的静态资源打包让我熬夜到三点,这坑千万别跳
前端·人工智能·后端
山河木马8 小时前
矩阵专题0-webGL中的矩阵
javascript·webgl·计算机图形学