使用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博客

相关推荐
古茗前端团队6 分钟前
让我带实习生,真的假的?
前端
我不吃饼干11 分钟前
倒反天罡,CSS 中竟然可以写 JavaScript
前端·javascript·css
10年前端老司机2 小时前
什么!纯前端也能识别图片中的文案、还支持100多个国家的语言
前端·javascript·vue.js
摸鱼仙人~2 小时前
React 性能优化实战指南:从理论到实践的完整攻略
前端·react.js·性能优化
程序员阿超的博客3 小时前
React动态渲染:如何用map循环渲染一个列表(List)
前端·react.js·前端框架
magic 2453 小时前
模拟 AJAX 提交 form 表单及请求头设置详解
前端·javascript·ajax
小小小小宇8 小时前
前端 Service Worker
前端
只喜欢赚钱的棉花没有糖8 小时前
http的缓存问题
前端·javascript·http
小小小小宇9 小时前
请求竞态问题统一封装
前端
loriloy9 小时前
前端资源帖
前端