使用css的transition属性实现抽屉功能

需求

使用css手写一个抽屉,并且不能遮挡住原来的页面

效果:(录的gif有点卡,实际情况很丝滑)

实现代码:

html 复制代码
<template>
  <div class="dashboard-container">
    <div class="mainBox"></div>
    <div id="drawerRight">
      <div class="iconDiv" @click="expandFn">展开</div>
    </div>
  </div>
</template>

<script>
export default {
  name: "drawer",
  data() {
    return {};
  },
  methods: {
    expandFn() {
      var Div = document.querySelector("div#drawerRight");
      var Btn = document.querySelector(".iconDiv");
      var mainDiv = document.querySelector(".mainBox");
      if (Btn.innerHTML === "展开") {
        Btn.innerHTML = "收起";
        Div.style.right = "0";
        mainDiv.style.width = "80%";
      } else if (Btn.innerHTML === "收起") {
        Div.style.right = "-15.5%";
        Btn.innerHTML = "展开";
        mainDiv.style.width = "95%";
      }
    },
  },
};
</script>

<style lang="scss" scoped>
.dashboard {
  &-container {
    margin: 30px;
    height: calc(100vh - 60px);
  }
  &-text {
    font-size: 30px;
    line-height: 46px;
  }
}
.mainBox {
  width: 95%;
  height: 80%;
  position: absolute;
  border: 1px dashed #0c99e6;
  transition: width linear 0.5s;

}
#drawerRight {
  position: relative;
  width: 16%;
  height: 80%;
  background-color: rgb(225, 216, 233) !important;
  padding: 20px;
  border-radius: 4px;
  position: absolute;
  right: -15.5%;
  transition: right linear 0.5s;
  .iconDiv {
    position: absolute;
    right: 100%;
    top: 45%;
    width: 30px;
    height: 80px;
    text-align: center;
    padding: 20px 5px;
    background-color: #0c99e6;
    color: #ffffff;
    border-radius: 4px;
    text-align: center;
    transition: right linear 0.5s;
    cursor: pointer;
    i {
      position: relative;
      top: 50%;
    }
  }
}
</style>

知识点:

1、这里主要使用了transition属性,transition属性是css3中的一个重要属性,可以为一个元素在不同样式之间变化添加补间动画。只需要定义开始状态和结束状态,就可以为我们添加补间动画。相较于传统的js实现的动画,transition属性实现的动画效果更细腻而且内存开销小。

2、transition属性有4个基本要素,分别是要过度的属性,动画时长,动画演变速度,延迟时间

3、transition可以过渡的属性有:

(1)所有数值属性都可以参与过度,比如width,height,left,top,border-radius

(2)背景颜色和文字颜色都可以过渡

(3)所有变形(包括2D和3D变换)都可以过渡

4、这里还使用了js原生写法,具体讲解可以看另一篇文章:前端基础知识--Document的常用属性和常用函数_document选择器-CSDN博客

相关推荐
Developer_Niuge15 分钟前
告别翻不动的 1000+ 书签:开源 Chrome / Edge 浏览器书签管理插件 Smart Bookmark 0.2 发布
前端·后端
用户527096487449018 分钟前
前端性能指标速查手册
前端
淹死在鱼塘的程序猿21 分钟前
🚀 告别"一次性聊天":揭秘让 AI 智能体越用越聪明的秘密武器 —— Skills
前端·人工智能·agent
掘金安东尼25 分钟前
OpenMUSE 全面详解:非扩散Transformer文生图开源基座(对标GPT Image 2)
前端·javascript·面试
~ rainbow~34 分钟前
前端转型全栈(六)——深入浅出:文件上传的原理与进阶
前端·http·文件上传
我就是马云飞1 小时前
我废了!大厂10年的我面了20家公司,面试官让我回去等通知!
android·前端·程序员
yizhiyang1 小时前
ECharts实战:滑动缩放+选中背景高亮,打造高颜值统计图表
前端
猫山月1 小时前
Flutter路由演进路线(2026)
前端·flutter
We་ct1 小时前
LeetCode 322. 零钱兑换:动态规划入门实战
前端·算法·leetcode·typescript·动态规划
_白_1 小时前
从 0 到上线:我如何用开源打造一款密码管理 Chrome 插件
javascript