vue3.2 汉堡按钮伸缩项(左侧菜单的伸缩)

本文介绍了如何在Vue应用中通过Vuex管理状态,实现Hamburger菜单的点击切换,并同步更新侧边栏和主内容区域的宽度。涉及组件引用、Vuex state与mutations的使用以及CSS的动态计算。

1、创建组件来使用,@/layout/components/hanburger.vue

2、引用到整体页面

3、vuex 中@/store/modules/app 设置参数,点击进行相关变化

 state: () => ({
    siderType: true,
  }),
 mutations: {
    changeSiderType(state) {
      state.siderType = !state.siderType
    },
  },

4.@/layout/components/hamburger.点击后图标的变化

<div class="hamburger-container" @click="toggleClick">
    <svg-icon :icon="icon"></svg-icon>
 </div>

//js中
// 使用vuex
import { useStore } from 'vuex'
import { computed } from 'vue'
const store = useStore()
const toggleClick = () => {
  store.commit('app/changeSiderType')
}
// 图标转换
const icon = computed(() => {
  return store.getters.siderType ? 'hamburger-opened' : 'hamburger-closed'
})

5、 menu是否折叠 @/layout/menu/index.vue

 :collapse="!$store.getters.siderType"

     菜单

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值