fix: fix topMenu align not work

This commit is contained in:
vben 2020-11-24 00:22:01 +08:00
parent 36734100e3
commit 25d43a5f7c
3 changed files with 20 additions and 18 deletions

View File

@ -26,11 +26,11 @@
}
.justify-start {
justify-content: start;
justify-content: flex-start;
}
.justify-end {
justify-content: end;
justify-content: flex-end;
}
.justify-around {

View File

@ -1,6 +1,6 @@
import './index.less';
import { defineComponent, unref, computed, ref } from 'vue';
import { defineComponent, unref, computed, ref, nextTick } from 'vue';
import { Layout, Tooltip, Badge } from 'ant-design-vue';
import { AppLogo } from '/@/components/Application';
@ -39,8 +39,8 @@ export default defineComponent({
setup() {
let logoEl: Element | null;
const widthRef = ref(200);
const logoWidthRef = ref(200);
const logoRef = ref<any>(null);
const { refreshPage } = useTabs();
const { getShowTopMenu, getShowHeaderTrigger, getSplit, getTopMenuAlign } = useMenuSetting();
@ -64,15 +64,17 @@ export default defineComponent({
useWindowSizeFn(
() => {
if (!unref(getShowTopMenu)) return;
let width = 0;
if (!logoEl) {
logoEl = document.querySelector('.layout-header__logo');
}
if (logoEl) {
width += logoEl.clientWidth;
}
widthRef.value = width + 60;
nextTick(() => {
if (!unref(getShowTopMenu)) return;
let width = 0;
if (!logoEl) {
logoEl = logoRef.value.$el;
}
if (logoEl) {
width += logoEl.clientWidth;
}
logoWidthRef.value = width + 80;
});
},
200,
{ immediate: true }
@ -105,11 +107,11 @@ export default defineComponent({
}
function renderHeaderContent() {
const width = unref(widthRef);
const width = unref(logoWidthRef);
return (
<div class="layout-header__content ">
{unref(getShowHeaderLogo) && (
<AppLogo class={`layout-header__logo`} theme={unref(getTheme)} />
<AppLogo class={`layout-header__logo`} ref={logoRef} theme={unref(getTheme)} />
)}
{unref(getShowContent) && (

View File

@ -12,7 +12,7 @@
&__left {
display: flex;
flex-grow: 1;
// flex-grow: 1;
align-items: center;
.layout-trigger {
@ -184,7 +184,7 @@
}
&__menu {
margin-left: 20px;
margin-left: 4px;
overflow: hidden;
align-items: center;
}