侧边栏的伸展与缩放

用到技术栈:

vue3+vite+element-plus

使用 CSS3 中的 transition 属性来实现平滑过渡效果。可以给 aside 元素添加 transition 属性,来让浏览器自动实现宽度变化的过渡动画

设置过渡时间为 0.3s,结合 will-change 属性进行优化---will-change: width;

将过渡时间延长到较长的时间段,或者使用缓动函数(如 ease-in-out)来实现更柔和的过渡效果

.aside {transition: width 0.8s ease-in-out 0.1;
}

transition-property  过渡值
添加过渡的属性,常见的取值有:

           transition-property: none【不选择任何需要过渡的属性】

           transition-property: all【选择所有可以过渡的属性】

           transition-property: property【指定需要过渡的属性,属性间用逗号分隔】
 

transition-duration  过渡时间
transition-duration指的是过渡效果持续的时间,单位为 s(秒)或者ms(毫秒)

           transition-duration: .5s ;

           transition-duration: 1000ms ;

           transition-duration: 2s ;

transition-timing-function 过渡速度
transition-timing-function 指的是过渡效果变化的快慢,常见的取值有:

           transition-timing-function: linear【匀速】

           transition-timing-function: ease【缓出-缓进】

           transition-timing-function: ease-in【缓出】

           transition-timing-function: ease-out【缓进】

           transition-timing-function: ease-in-out【缓出-缓进,较ease更慢一些】

           transition-timing-function: cubic-bezier(n,n,n,n)【利用贝塞尔曲线自定义过渡速度】

transition-delay 过渡延迟
        transition-timing-function 能使过渡效果延迟一段时间后发生,同 transition-duration         过渡时间一样,单位为 s(秒)或者ms(毫秒)

代码实现

<template><div class="home"><el-radio-group v-model="isCollapse" style="margin-bottom: 20px"><el-radio-button :label="false">expand</el-radio-button><el-radio-button :label="true">collapse</el-radio-button></el-radio-group><el-container class="cont1"><el-header class="header">Header</el-header><el-container class="cont2"><el-aside :width="asideWidth" class="aside">// 触发事件的元素标签 <p class="xianyin" @click="handleAsideClick">|||</p><el-menu active-text-color="#ffd04b" background-color="#545c64" class="el-menu" default-active="2"text-color="#fff" @open="handleOpen" @close="handleClose" :collapse="isCollapse"><el-sub-menu index="1"><template #title><el-icon><location /></el-icon><span>基础档案</span></template><el-menu-item index="1-1">item one</el-menu-item><el-menu-item index="1-2">item two</el-menu-item><el-menu-item index="1-3">item three</el-menu-item><el-sub-menu index="1-4"><template #title>item four</template><el-menu-item index="1-4-1">仓库设置</el-menu-item></el-sub-menu></el-sub-menu><el-menu-item index="2"><el-icon><icon-menu /></el-icon><span>采购管理</span></el-menu-item><el-menu-item index="3" disabled><el-icon><document /></el-icon><span>Navigator Three</span></el-menu-item><el-menu-item index="4"><el-icon><setting /></el-icon><span>Navigator Four</span></el-menu-item></el-menu></el-aside><el-main class="main"><RouterView/></el-main></el-container></el-container></div>
</template><script setup>
import { ref, onMounted,nextTick } from 'vue'
import {RouterView} from 'vue-router'
import {Document,Menu as IconMenu,Location,Setting,
} from '@element-plus/icons-vue'
import router from '@/router';
// 状态的判断
const isCollapse = ref(localStorage.getItem('isCollapse') === 'true');
const asideWidth = ref(localStorage.getItem('asideWidth') || '200px');// 使用了nextTick()函数来等待页面加载完成,然后再将asideWidth的值从本地缓存中获取并进行更新,在
// 页面加载完成之后,才会应用正确的侧边栏宽度,从而避免抖动的问题 
onMounted(async () => {await nextTick(); // 等待页面加载完成asideWidth.value = localStorage.getItem('asideWidth') || '200px';
});const handleAsideClick = () => {// 点击后状态取反isCollapse.value = !isCollapse.value;// 状态存入到本地存储中localStorage.setItem('isCollapse', isCollapse.value.toString());asideWidth.value = isCollapse.value ? '60px' : '200px';// 宽度存入到本地存储中localStorage.setItem('asideWidth', asideWidth.value);
};// 官方的,没用到
const handleOpen = (key, keyPath) => {console.log(key, keyPath)
}
const handleClose = (key, keyPath) => {console.log(key, keyPath)
}
</script><style scoped lang="less">
.home {height: 100%;.cont1 {height: 100%;.header {height: 50px;background-color: aliceblue;}.cont2 {height: 100%;.aside {height: 100%;// 动画的实现will-change: width;transition: width 0.6s ease-in-out 0.1s;overflow: hidden;.xianyin{width: 100%;height: 20px;text-align: center;background-color: cadetblue;}.el-menu {height: 100%;}}.main {height: 100%;background-color: cornsilk;margin: 15px;}}}
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/634774.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024-01-17(SpringCloud)

1.使用openFeign的itemClient接口去做远程调用其他微服务中的接口。但我们直接使用了itemClient接口&#xff0c;而不是该接口的实现类&#xff0c;说明我们是使用该接口的代理对象帮我们做远程调用的。这个代理对象是invocationHandler来生成的。 2.openFeign底层发起远程调用…

什么是DOM?(JavaScript DOM是什么?)

1、DOM简洁 DOM是js中最重要的一部分&#xff0c;没有DOM就不会通过js实现和用户之间的交互。 window是最大的浏览器对象&#xff0c;在它的下面还有很多子对象&#xff0c;我们要学习的DOM就是window对象下面的document对象 DOM&#xff08;Document Object Model&#xff09…

【数学建模美赛论文word模板更新】数学建模美赛O/F奖论文word写作模板——研赛国赛国一、美赛F/O奖学长联合制作

参加美赛不知道论文如何写、如何排版&#xff1f;快来领取免费模板哦~ 我们的word模板由研赛国赛国一、美赛F/O奖学长联合制作。 论文模板是论文的一部分&#xff0c;它代表着你的论文从构思到完成的全过程&#xff0c;是论文的雏形。 论文模板能够节省你的写作时间&#xf…

深入探讨生产环境中秒杀接口并发量剧增、负载过高的情况该如何应对?

目录 引言 1. 实施限流措施 1.1 令牌桶算法&#xff1a; 1.2 漏桶算法&#xff1a; 1.3 使用限流框架&#xff1a; 2. 优化数据库操作 2.1. 索引优化 2.2. 批量操作减少交互次数&#xff1a; 2.3. 避免全表扫描&#xff1a; 2.4使用InnoDB引擎&#xff1a; 2.5优化事…

力扣59-螺旋矩阵

螺旋矩阵 题目链接 class Solution { public:vector<vector<int>> generateMatrix(int n) {vector<vector<int>>res(n, vector<int>(n, 0));int dx[4] {0, 1, 0, -1}, dy[4] {1, 0, -1, 0}; //方向偏移数组int x 0, y 0; //当前位置for(…

一、可行性研究报告模板(软件工程)

一、可行性研究报告 1&#xff0e;引言 1.1编写目的 1.2项目背景 1.3定义 1.4参考资料 2&#xff0e;可行性研究的前提 2.1要求 2.2目标 2.3条件、假定和限制 2.4可行性研究方法 2.5决定可行性的主要因素 3&#xff0e;对现有系统的分析 3.1处理流程…

设计模式之7大设计原则-Java版

软件设计模式是前辈们代码设计经验的总结&#xff0c;可以反复使用。设计模式共分为3大类&#xff0c;创建者模式(5种)、结构型模式(7种)、行为型模式(11种)&#xff0c;一共23种设计模式&#xff0c;软件设计一般需要满足7大基本原则。下面通过5章的学习一起来看看设计模式的魅…

当MySql有字段为null,索引是否会失效

sql执行过程中,使用is null 或者is not null 理论上都会走索引,由于优化器的原因导致索引失效变成全表扫描,或者说是否使用索引和NULL值本身没有直接关系,和执行成本有关系。 数据行记录如何存储NULL值的&#xff1f; InnoDB 提供了 4 种行格式 Redundant:非紧凑格式,5.0 版…

01.CheckStyle代码检查工具

CheckStyle代码检查工具 1.介绍 Checkstyle 是一种开发工具&#xff0c;可帮助程序员编写符合编码标准的 Java 代码。它使检查 Java 代码的过程自动化&#xff0c;从而使开发者免于完成这项无聊&#xff08;但重要&#xff09;的任务。这使得它非常适合想要强制执行编码标准的…

What is `JsonSanitizer.sanitize` does?

JsonSanitizer.sanitize 是一个Java库中的方法&#xff0c;用于处理和净化JSON字符串&#xff0c;特别是针对跨站脚本攻击&#xff08;XSS, Cross-Site Scripting&#xff09;。 例如&#xff0c;在处理富文本内容、用户评论、从第三方服务获取的数据时&#xff0c;使用 JsonSa…

高级架构师是如何设计一个系统的?

架构师如何设计系统&#xff1f; 系统拆分 通过DDD领域模型&#xff0c;对服务进行拆分&#xff0c;将一个系统拆分为多个子系统&#xff0c;做成SpringCloud的微服务。微服务设计时要尽可能做到少扇出&#xff0c;多扇入&#xff0c;根据服务器的承载&#xff0c;进行客户端负…

123 二叉树的序列化于反序列化

问题描述&#xff1a;序列化是将一个数据结构或者对象转换为连续的比特位的操作&#xff0c;进而可以将转换后的数据存储在一个文件或者内存中&#xff0c;同时也可以通过网络传输到另一个九四u安吉环境&#xff0c;采用相反的重构方式得到原数据&#xff0c;请设计一个算法实现…

微信这个费用,终于降低了

大家好&#xff0c;我是小悟 这个费用降低了&#xff0c;这对于广大小程序开发者来说无疑是一个好消息。这一举措不仅可以降低开发者的成本&#xff0c;还有助于激发更多的创新和创业激情。 对于广大小程序开发者来说&#xff0c;这也是一个福音&#xff0c;因为他们可以降低开…

DMA技术在STM32中优化UART、SPI和I2C通信性能的研究与实现

DMA&#xff08;Direct Memory Access&#xff0c;直接存储器访问&#xff09;技术可以在STM32微控制器上优化UART、SPI和I2C等通信性能。DMA可以实现数据的高速传输&#xff0c;减轻CPU的负担&#xff0c;提高系统性能。在本篇文章中&#xff0c;我将探讨DMA技术在STM32中优化…

【计算机组成原理】

【第一章】计算机系统概述 【第二章】进程管理

RDMA编程实践-SEND-RECEICVE原语应用

RDMA编程实践 本文描述了RDMA编程过程中的SEND-RECEIVE双边原语的代码实现。包含多个版本&#xff0c;1、client向server发送消息&#xff0c;server回复client收到消息(ACK)&#xff0c;然后两边断开连接。2、server端循环等待客户端建立连接&#xff0c;client发送一次消息后…

rocketmq双主双从部署+dashbord

1、主机规划 主机节点地址主机Anamesrv192.168.2.228:9876主机Abroker-a192.168.2.228:10911主机Abroker-b192.168.2.228:11911主机Bnamesrv192.168.2.229:9876主机Bbroker-c192.168.2.229:10911主机Bbroker-d192.168.2.229:11911 2、两台主机都需要执行&#xff0c;创建mq需…

Javaweb之SpringBootWeb案例员工管理之删除员工的详细解析

3.3 删除员工 查询员完成之后&#xff0c;我们继续开发新的功能&#xff1a;删除员工。 3.3.1 需求 当我们勾选列表前面的复选框&#xff0c;然后点击 "批量删除" 按钮&#xff0c;就可以将这一批次的员工信息删除掉了。也可以只勾选一个复选框&#xff0c;仅删除一…

超详细的 pytest 钩子函数 —— 之初始钩子和引导钩子来啦!

前几篇文章介绍了 pytest 点的基本使用&#xff0c;学完前面几篇的内容基本上就可以满足工作中编写用例和进行自动化测试的需求。从这篇文章开始会陆续给大家介绍 pytest 中的钩子函数&#xff0c;插件开发等等。 仔细去看过 pytest 文档的小伙伴&#xff0c;应该都有发现 pyt…

PSP - 提取 UniRef 数据库搜索的 MSA 序列物种 (Species) 信息

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/135702185 UniRef库&#xff1a;UniProt参考聚类&#xff08;UniRef&#xff09;的简称&#xff0c;提供了从UniProt知识库&#xff08;包括异构体…