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

相关推荐
JMS_兔子6 分钟前
elementUI非常规数据格式渲染复杂表格(副表头、合并单元格)
前端·javascript·elementui·vue
九圣残炎11 分钟前
【Vue】Ego商城项目跟做
前端·javascript·vue.js·node.js
zhenryx19 分钟前
前端node.js
前端·node.js
Blue桃之夭夭35 分钟前
CSDN设置成黑色背景(谷歌 Edge)
前端·edge
一棵开花的树,枝芽无限靠近你42 分钟前
【element-tiptap】导出word
前端·笔记·学习·编辑器·word·element-tiptap
逝去的紫枫1 小时前
Python 中的 Lxml 库与 XPath 用法
开发语言·前端·python
前端青山1 小时前
Vue-常用指令
开发语言·前端·javascript·vue.js·前端框架
折腾的小飞1 小时前
前端通用Axios 请求拦截配置
前端·javascript·vue.js·axios·anti-design-vue
芭拉拉小魔仙1 小时前
Ajax、Fetch、Axios、XMLHttpRequest 的关系与区别
前端·javascript·ajax
徐同保1 小时前
web3js查询钱包余额
开发语言·javascript·web3