feat: menu 支持配置 _blank 在新页面打开 (#258)

This commit is contained in:
qlin 2024-11-19 10:54:24 +08:00 committed by GitHub
parent 4b3fb7b3d1
commit eb6ed75dd4
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 20 additions and 3 deletions

View File

@ -300,6 +300,7 @@ export const layout = {
```
- **children**:子菜单配置。
- **_blank**:是否在新的窗口打开页面,默认 http 开头的链接在新窗口打开
:::tip
函数类型仅在运行时可用,可以实现动态变更菜单。

View File

@ -126,8 +126,15 @@ export default {
const onMenuClick = (e) => {
const path = e.value;
const currentMenu = menuArray.value.find(item => item.value === path);
if (/^https?:\/\//.test(path)) {
if (currentMenu._blank) {
const resolved = router.resolve({
path,
query: currentMenu?.query || {},
params: currentMenu?.params || {},
});
window.open(resolved.href, '_blank');
}
else if (/^https?:\/\//.test(path)) {
window.open(path, '_blank');
}
else if (/^\//.test(path)) {

View File

@ -135,6 +135,9 @@ export default {
const handleCloseTab = async (targetKey) => {
targetKey = targetKey || route.path;
const selectedPage = findPage(targetKey);
if (!selectedPage) {
return;
}
const list = [...pageList.value];
const index = list.indexOf(selectedPage);
if (route.path === selectedPage.path) {

View File

@ -47,6 +47,7 @@ export default defineBuildConfig({
{
name: 'editor',
icon: '/wine-outline.svg',
_blank: true,
},
{
title: '$externalLink',
@ -70,6 +71,7 @@ export default defineBuildConfig({
},
{
name: 'pinia',
_blank: true,
},
],
menuProps: {

View File

@ -1,7 +1,10 @@
<template>
<div>{{ store.counter }}</div>
<FButton class="m-2" @click="store.increment">Button</FButton>
<FButton class="m-2" @click="store.increment">
Button
</FButton>
</template>
<config>
{
"name": "pinia",
@ -11,6 +14,7 @@
}
}
</config>
<script>
import { FButton } from '@fesjs/fes-design';
import { useStore } from '@/store/main';