refactor: some feat pages transfer setup grammar (#3292)

* refactor: some feat pages transfer setup grammar

* refactor: update
This commit is contained in:
bowen 2023-11-18 09:26:59 +08:00 committed by GitHub
parent 72ef3df57f
commit cb907165ec
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
19 changed files with 309 additions and 451 deletions

View File

@ -3,11 +3,7 @@
<router-link to="/feat/breadcrumb/children/childrenDetail"> 进入子级详情页 </router-link>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import { PageWrapper } from '/@/components/Page';
export default defineComponent({
components: { PageWrapper },
});
<script lang="ts" setup>
import { PageWrapper } from '/@/components/Page';
</script>

View File

@ -3,9 +3,7 @@
<div>子级详情页内容在此</div>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import { PageWrapper } from '/@/components/Page';
export default defineComponent({ components: { PageWrapper } });
<script lang="ts" setup>
import { PageWrapper } from '/@/components/Page';
</script>

View File

@ -3,11 +3,6 @@
<router-link to="/feat/breadcrumb/flatDetail"> 进入平级详情页 </router-link>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
<script lang="ts" setup>
import { PageWrapper } from '/@/components/Page';
export default defineComponent({
components: { PageWrapper },
});
</script>

View File

@ -1,8 +1,3 @@
<template>
<div>平级详情页</div>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
export default defineComponent({});
</script>

View File

@ -7,25 +7,21 @@
</ClickOutSide>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent, ref } from 'vue';
import { ClickOutSide } from '/@/components/ClickOutSide';
<script lang="ts" setup>
import { ref } from 'vue';
import { PageWrapper } from '/@/components/Page';
import { ClickOutSide } from '/@/components/ClickOutSide';
export default defineComponent({
components: { ClickOutSide, PageWrapper },
setup() {
const text = ref('Click');
function handleClickOutside() {
text.value = 'Click Out Side';
}
const text = ref('Click');
function innerClick() {
text.value = 'Click Inner';
}
return { innerClick, handleClickOutside, text };
},
});
function handleClickOutside() {
text.value = 'Click Out Side';
}
function innerClick() {
text.value = 'Click Inner';
}
</script>
<style lang="less" scoped>

View File

@ -9,77 +9,71 @@
</CollapseContainer>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import { useContextMenu } from '/@/hooks/web/useContextMenu';
import { CollapseContainer } from '/@/components/Container';
<script lang="ts" setup>
import { useMessage } from '/@/hooks/web/useMessage';
import { useContextMenu } from '/@/hooks/web/useContextMenu';
import { PageWrapper } from '/@/components/Page';
import { CollapseContainer } from '/@/components/Container';
export default defineComponent({
components: { CollapseContainer, PageWrapper },
setup() {
const [createContextMenu] = useContextMenu();
const { createMessage } = useMessage();
function handleContext(e: MouseEvent) {
createContextMenu({
event: e,
items: [
const { createMessage } = useMessage();
const [createContextMenu] = useContextMenu();
function handleContext(e: MouseEvent) {
createContextMenu({
event: e,
items: [
{
label: 'New',
icon: 'bi:plus',
handler: () => {
createMessage.success('click new');
},
},
{
label: 'Open',
icon: 'bx:bxs-folder-open',
handler: () => {
createMessage.success('click open');
},
},
],
});
}
function handleMultipleContext(e: MouseEvent) {
createContextMenu({
event: e,
items: [
{
label: 'New',
icon: 'bi:plus',
children: [
{
label: 'New',
label: 'New1-1',
icon: 'bi:plus',
handler: () => {
createMessage.success('click new');
},
},
{
label: 'Open',
icon: 'bx:bxs-folder-open',
handler: () => {
createMessage.success('click open');
},
},
],
});
}
function handleMultipleContext(e: MouseEvent) {
createContextMenu({
event: e,
items: [
{
label: 'New',
icon: 'bi:plus',
divider: true,
children: [
{
label: 'New1-1',
icon: 'bi:plus',
divider: true,
children: [
{
label: 'New1-1-1',
handler: () => {
createMessage.success('click new');
},
},
{
label: 'New1-2-1',
disabled: true,
},
],
label: 'New1-1-1',
handler: () => {
createMessage.success('click new');
},
},
{
label: 'New1-2',
icon: 'bi:plus',
label: 'New1-2-1',
disabled: true,
},
],
},
{
label: 'New1-2',
icon: 'bi:plus',
},
],
});
}
return { handleContext, handleMultipleContext };
},
});
},
],
});
}
</script>

View File

@ -2,35 +2,29 @@
<PageWrapper title="文本复制示例">
<CollapseContainer class="w-full h-32 bg-white rounded-md" title="Copy Example">
<div class="flex justify-center">
<a-input placeholder="请输入" v-model:value="value" />
<a-input placeholder="请输入" v-model:value="copyValue" />
<a-button type="primary" @click="handleCopy"> Copy </a-button>
</div>
</CollapseContainer>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent, unref, ref } from 'vue';
import { CollapseContainer } from '/@/components/Container/index';
<script lang="ts" setup>
import { unref, ref } from 'vue';
import { useMessage } from '/@/hooks/web/useMessage';
import { PageWrapper } from '/@/components/Page';
import { copyText } from '/@/utils/copyTextToClipboard';
export default defineComponent({
name: 'Copy',
components: { CollapseContainer, PageWrapper },
setup() {
const valueRef = ref('');
const { createMessage } = useMessage();
import { PageWrapper } from '/@/components/Page';
import { CollapseContainer } from '/@/components/Container/index';
function handleCopy() {
const value = unref(valueRef);
if (!value) {
createMessage.warning('请输入要拷贝的内容!');
return;
}
copyText(value);
}
return { handleCopy, value: valueRef };
},
});
const copyValue = ref('');
const { createMessage } = useMessage();
function handleCopy() {
const value = unref(copyValue);
if (!value) {
createMessage.warning('请输入要拷贝的内容!');
return;
}
copyText(value);
}
</script>

View File

@ -15,8 +15,7 @@
</a-button>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
<script lang="ts" setup>
import {
downloadByUrl,
downloadByData,
@ -27,40 +26,32 @@
import { PageWrapper } from '/@/components/Page';
import { Alert } from 'ant-design-vue';
export default defineComponent({
components: { PageWrapper, [Alert.name]: Alert },
setup() {
function handleDownByData() {
downloadByData('text content', 'testName.txt');
}
function handleDownloadByUrl() {
downloadByUrl({
url: 'https://codeload.github.com/anncwb/vue-vben-admin-doc/zip/master',
target: '_self',
});
const AAlert = Alert;
downloadByUrl({
url: 'https://vebn.oss-cn-beijing.aliyuncs.com/vben/logo.png',
target: '_self',
});
}
function handleDownByData() {
downloadByData('text content', 'testName.txt');
}
function handleDownloadByBase64() {
downloadByBase64(imgBase64, 'logo.png');
}
function handleDownloadByUrl() {
downloadByUrl({
url: 'https://codeload.github.com/anncwb/vue-vben-admin-doc/zip/master',
target: '_self',
});
function handleDownloadByOnlineUrl() {
downloadByOnlineUrl(
'https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/5944817f47b8408e9f1442ece49d68ca~tplv-k3u1fbpfcp-watermark.image',
'logo.png',
);
}
return {
handleDownloadByUrl,
handleDownByData,
handleDownloadByBase64,
handleDownloadByOnlineUrl,
};
},
});
downloadByUrl({
url: 'https://vebn.oss-cn-beijing.aliyuncs.com/vben/logo.png',
target: '_self',
});
}
function handleDownloadByBase64() {
downloadByBase64(imgBase64, 'logo.png');
}
function handleDownloadByOnlineUrl() {
downloadByOnlineUrl(
'https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/5944817f47b8408e9f1442ece49d68ca~tplv-k3u1fbpfcp-watermark.image',
'logo.png',
);
}
</script>

View File

@ -22,26 +22,16 @@
</CollapseContainer>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent, ref } from 'vue';
import { CollapseContainer } from '/@/components/Container/index';
<script lang="ts" setup>
import { PageWrapper } from '/@/components/Page';
import { EllipsisText } from '@/components/EllipsisText';
import { CollapseContainer } from '/@/components/Container/index';
export default defineComponent({
name: 'Ellipsis',
components: { CollapseContainer, PageWrapper, EllipsisText },
setup() {
const text =
ref(`Vue-Vben-Admin 是一个基于 Vue3.0、Vite、 Ant-Design-Vue、TypeScript 的后台解决方案,目标是为开发中大型项目提供开箱即用的解决方案。
const text = `Vue-Vben-Admin 是一个基于 Vue3.0、Vite、 Ant-Design-Vue、TypeScript 的后台解决方案,目标是为开发中大型项目提供开箱即用的解决方案。
包括二次封装组件utilshooks动态菜单权限校验按钮级别权限控制等功能项目会使用前端较新的技术栈可以作为项目的启动模版以帮助你快速搭建企业级中后台产品原型
也可以作为一个示例用于学习 vue3vitets 等主流技术该项目会持续跟进最新技术并将其应用在项目中Vue-Vben-Admin 是一个基于 Vue3.0Vite Ant-Design-VueTypeScript 的后台解决方案目标是为开发中大型项目提供开箱即用的解决方案
包括二次封装组件utilshooks动态菜单权限校验按钮级别权限控制等功能项目会使用前端较新的技术栈可以作为项目的启动模版以帮助你快速搭建企业级中后台产品原型
也可以作为一个示例用于学习 vue3vitets 等主流技术该项目会持续跟进最新技术并将其应用在项目中Vue-Vben-Admin 是一个基于 Vue3.0Vite Ant-Design-VueTypeScript 的后台解决方案目标是为开发中大型项目提供开箱即用的解决方案
包括二次封装组件utilshooks动态菜单权限校验按钮级别权限控制等功能项目会使用前端较新的技术栈可以作为项目的启动模版以帮助你快速搭建企业级中后台产品原型
也可以作为一个示例用于学习 vue3vitets 等主流技术该项目会持续跟进最新技术并将其应用在项目中`);
return { text };
},
});
也可以作为一个示例用于学习 vue3vitets 等主流技术该项目会持续跟进最新技术并将其应用在项目中`;
</script>

View File

@ -25,30 +25,18 @@
</div>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent, ref } from 'vue';
import { CollapseContainer } from '/@/components/Container/index';
<script lang="ts" setup>
import { ref } from 'vue';
import { useFullscreen } from '@vueuse/core';
import { CollapseContainer } from '/@/components/Container/index';
import { PageWrapper } from '/@/components/Page';
import { type Nullable } from '@vben/types';
export default defineComponent({
components: { CollapseContainer, PageWrapper },
setup() {
const domRef = ref<Nullable<HTMLElement>>(null);
const { enter, toggle, exit, isFullscreen } = useFullscreen();
import type { Nullable } from '@vben/types';
const { toggle: toggleDom, isFullscreen: isDomFullscreen } = useFullscreen(domRef);
return {
enter,
toggleDom,
toggle,
isFullscreen,
isDomFullscreen,
exit,
domRef,
};
},
});
const domRef = ref<Nullable<HTMLElement>>(null);
const { enter, toggle, exit, isFullscreen } = useFullscreen();
const { toggle: toggleDom, isFullscreen: isDomFullscreen } = useFullscreen(domRef);
</script>

View File

@ -50,8 +50,7 @@
<a-button type="link" @click="toIconify"> Iconify 图标大全 </a-button>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
<script lang="ts" setup>
import { CollapseContainer } from '/@/components/Container/index';
import { Alert } from 'ant-design-vue';
import {
@ -70,28 +69,7 @@
import { openWindow } from '/@/utils';
import { PageWrapper } from '/@/components/Page';
export default defineComponent({
components: {
PageWrapper,
CollapseContainer,
GithubFilled,
QqCircleFilled,
WechatFilled,
AlipayCircleFilled,
IeCircleFilled,
TaobaoCircleFilled,
CodepenCircleFilled,
Icon,
Alert,
IconPicker,
SvgIcon,
},
setup() {
return {
toIconify: () => {
openWindow('https://iconify.design/');
},
};
},
});
const toIconify = () => {
openWindow('https://iconify.design/');
};
</script>

View File

@ -4,28 +4,22 @@
<a-button @click="openImg" type="primary">无预览图</a-button>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import { createImgPreview, ImagePreview } from '/@/components/Preview/index';
import { PageWrapper } from '/@/components/Page';
// import { PreviewActions } from '/@/components/Preview/src/typing';
const imgList: string[] = [
<script lang="ts" setup>
import { PageWrapper } from '/@/components/Page';
import { createImgPreview, ImagePreview } from '/@/components/Preview/index';
const imgList = [
'https://picsum.photos/id/66/346/216',
'https://picsum.photos/id/67/346/216',
'https://picsum.photos/id/68/346/216',
];
export default defineComponent({
components: { PageWrapper, ImagePreview },
setup() {
function openImg() {
const onImgLoad = ({ index, url, dom }) => {
console.log(`${index + 1}张图片已加载URL为${url}`, dom);
};
// 使createImgPreview PreviewActions
createImgPreview({ imageList: imgList, defaultWidth: 700, rememberState: true, onImgLoad });
}
return { imgList, openImg };
},
});
function openImg() {
const onImgLoad = ({ index, url, dom }) => {
console.log(`${index + 1}张图片已加载URL为${url}`, dom);
};
// 使createImgPreview PreviewActions
createImgPreview({ imageList: imgList, defaultWidth: 700, rememberState: true, onImgLoad });
}
</script>

View File

@ -1,6 +1,6 @@
<template>
<PageWrapper title="带参数菜单(路由)" content="支持多级参数">
当前参数{{ params }}
当前参数{{ computedParams }}
<br />
输入参数切换路由
<Input v-model:value="value" placeholder="建议为url标准字符输入后点击切换" />
@ -13,30 +13,21 @@
</ul>
</PageWrapper>
</template>
<script lang="ts">
import { Input } from 'ant-design-vue';
import { computed, defineComponent, ref, unref } from 'vue';
<script lang="ts" setup>
import { useRouter } from 'vue-router';
import { computed, ref, unref } from 'vue';
import { Input } from 'ant-design-vue';
import { PageWrapper } from '/@/components/Page';
export default defineComponent({
name: 'TestMenu',
components: { PageWrapper, Input },
setup() {
const { currentRoute, replace } = useRouter();
const value = ref<string>('');
const value = ref('');
const handleClickGo = () => {
const { name } = unref(currentRoute);
replace({ name: name!, params: { id: unref(value) } });
};
return {
value,
handleClickGo,
params: computed(() => {
return unref(currentRoute).params;
}),
};
},
});
const { currentRoute, replace } = useRouter();
const computedParams = computed(() => unref(currentRoute).params);
const handleClickGo = () => {
const { name } = unref(currentRoute);
replace({ name: name!, params: { id: unref(value) } });
};
</script>

View File

@ -34,67 +34,61 @@
</CollapseContainer>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import { CollapseContainer } from '/@/components/Container/index';
import { useMessage } from '/@/hooks/web/useMessage';
<script lang="ts" setup>
import { PageWrapper } from '/@/components/Page';
import { CollapseContainer } from '/@/components/Container/index';
export default defineComponent({
components: { CollapseContainer, PageWrapper },
setup() {
const {
createMessage,
createConfirm,
createSuccessModal,
createInfoModal,
createErrorModal,
createWarningModal,
notification,
} = useMessage();
const { info, success, warning, error } = createMessage;
import { useMessage } from '/@/hooks/web/useMessage';
function handleLoading() {
createMessage.loading('Loading...');
}
function handleConfirm(type: 'warning' | 'error' | 'success' | 'info') {
createConfirm({
iconType: type,
title: 'Tip',
content: 'content message...',
});
}
function handleSuccessModal() {
createSuccessModal({ title: 'Tip', content: 'content message...' });
}
function handleErrorModal() {
createErrorModal({ title: 'Tip', content: 'content message...' });
}
function handleWarningModal() {
createWarningModal({ title: 'Tip', content: 'content message...' });
}
function handleInfoModal() {
createInfoModal({ title: 'Tip', content: 'content message...' });
}
function handleNotify() {
notification.success({
message: 'Tip',
description: 'content message...',
});
}
return {
infoMsg: info,
successMsg: success,
warningMsg: warning,
errorMsg: error,
handleLoading,
handleConfirm,
handleSuccessModal,
handleErrorModal,
handleWarningModal,
handleInfoModal,
handleNotify,
};
},
});
const {
createMessage,
createConfirm,
createSuccessModal,
createInfoModal,
createErrorModal,
createWarningModal,
notification,
} = useMessage();
const {
info: infoMsg,
success: successMsg,
warning: warningMsg,
error: errorMsg,
} = createMessage;
function handleLoading() {
createMessage.loading('Loading...');
}
function handleConfirm(type: 'warning' | 'error' | 'success' | 'info') {
createConfirm({
iconType: type,
title: 'Tip',
content: 'content message...',
});
}
function handleSuccessModal() {
createSuccessModal({ title: 'Tip', content: 'content message...' });
}
function handleErrorModal() {
createErrorModal({ title: 'Tip', content: 'content message...' });
}
function handleWarningModal() {
createWarningModal({ title: 'Tip', content: 'content message...' });
}
function handleInfoModal() {
createInfoModal({ title: 'Tip', content: 'content message...' });
}
function handleNotify() {
notification.success({
message: 'Tip',
description: 'content message...',
});
}
</script>

View File

@ -7,43 +7,32 @@
<a-button type="primary" class="mt-5" @click="imagePrint">Image Print</a-button>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
<script lang="ts" setup>
import { PageWrapper } from '/@/components/Page';
import { CollapseContainer } from '/@/components/Container/index';
import printJS from 'print-js';
export default defineComponent({
name: 'AppLogo',
components: { PageWrapper, CollapseContainer },
setup() {
function jsonPrint() {
printJS({
printable: [
{ name: 'll', email: '123@gmail.com', phone: '123' },
{ name: 'qq', email: '456@gmail.com', phone: '456' },
],
properties: ['name', 'email', 'phone'],
type: 'json',
});
}
function jsonPrint() {
printJS({
printable: [
{ name: 'll', email: '123@gmail.com', phone: '123' },
{ name: 'qq', email: '456@gmail.com', phone: '456' },
],
properties: ['name', 'email', 'phone'],
type: 'json',
});
}
function imagePrint() {
printJS({
printable: [
'https://anncwb.github.io/anncwb/images/preview1.png',
'https://anncwb.github.io/anncwb/images/preview2.png',
],
type: 'image',
header: 'Multiple Images',
imageStyle: 'width:100%;',
});
}
return {
jsonPrint,
imagePrint,
};
},
});
function imagePrint() {
printJS({
printable: [
'https://anncwb.github.io/anncwb/images/preview1.png',
'https://anncwb.github.io/anncwb/images/preview2.png',
],
type: 'image',
header: 'Multiple Images',
imageStyle: 'width:100%;',
});
}
</script>

View File

@ -14,41 +14,35 @@
</a-card>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
<script lang="ts" setup>
import { PageWrapper } from '/@/components/Page';
import { useUserStore } from '/@/store/modules/user';
import { sessionTimeoutApi, tokenExpiredApi } from '/@/api/demo/account';
import { Card } from 'ant-design-vue';
export default defineComponent({
name: 'TestSessionTimeout',
components: { ACardGrid: Card.Grid, ACard: Card, PageWrapper },
setup() {
const userStore = useUserStore();
async function test1() {
// mockHttp
//
if (import.meta.env.PROD) {
userStore.setToken(undefined);
userStore.setSessionTimeout(true);
} else {
// api401
await sessionTimeoutApi();
}
}
const ACardGrid = Card.Grid;
const ACard = Card;
async function test2() {
// apicode401jsonHttp200
try {
await tokenExpiredApi();
} catch (err) {
console.log('接口访问错误:', (err as Error).message || '错误');
}
}
const userStore = useUserStore();
async function test1() {
// mockHttp
//
if (import.meta.env.PROD) {
userStore.setToken(undefined);
userStore.setSessionTimeout(true);
} else {
// api401
await sessionTimeoutApi();
}
}
return { test1, test2 };
},
});
async function test2() {
// apicode401jsonHttp200
try {
await tokenExpiredApi();
} catch (err) {
console.log('接口访问错误:', (err as Error).message || '错误');
}
}
</script>

View File

@ -1,27 +1,24 @@
<template>
<PageWrapper title="带参数标签页" content="支持带参数多tab缓存">
Current Param : {{ params }}
Current Param : {{ computedParams }}
<br />
Keep Alive
<Input />
</PageWrapper>
</template>
<script lang="ts">
import { computed, defineComponent, unref } from 'vue';
import { useRouter } from 'vue-router';
import { PageWrapper } from '/@/components/Page';
import { Input } from 'ant-design-vue';
export default defineComponent({
<script lang="ts" setup>
import { computed, unref } from 'vue';
import { useRouter } from 'vue-router';
import { Input } from 'ant-design-vue';
import { PageWrapper } from '/@/components/Page';
const { currentRoute } = useRouter();
defineOptions({
name: 'TestTab',
components: { PageWrapper, Input },
setup() {
const { currentRoute } = useRouter();
return {
params: computed(() => {
return unref(currentRoute).params;
}),
};
},
});
const computedParams = computed(() => unref(currentRoute).params);
</script>

View File

@ -4,25 +4,16 @@
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import { PageWrapper } from '/@/components/Page';
import { useTabs } from '/@/hooks/web/useTabs';
<script lang="ts" setup>
import { useRoute } from 'vue-router';
import { useTabs } from '/@/hooks/web/useTabs';
export default defineComponent({
name: 'TabDetail',
components: { PageWrapper },
setup() {
const route = useRoute();
const index = route.params?.id ?? -1;
const { setTitle } = useTabs();
import { PageWrapper } from '/@/components/Page';
//
setTitle(`No.${index} - 详情信息`);
return {
index,
};
},
});
const route = useRoute();
const index = route.params?.id ?? -1;
const { setTitle } = useTabs();
//
setTitle(`No.${index} - 详情信息`);
</script>

View File

@ -24,46 +24,39 @@
</CollapseContainer>
</PageWrapper>
</template>
<script lang="ts">
import { defineComponent, ref } from 'vue';
import { CollapseContainer } from '/@/components/Container';
import { useTabs } from '/@/hooks/web/useTabs';
import { PageWrapper } from '/@/components/Page';
import { Input, Alert } from 'ant-design-vue';
import { useMessage } from '/@/hooks/web/useMessage';
<script lang="ts" setup>
import { ref } from 'vue';
import { useGo } from '/@/hooks/web/usePage';
import { useTabs } from '/@/hooks/web/useTabs';
import { useMessage } from '/@/hooks/web/useMessage';
export default defineComponent({
import { Input, Alert } from 'ant-design-vue';
import { PageWrapper } from '/@/components/Page';
import { CollapseContainer } from '/@/components/Container';
const AInput = Input;
const AAlert = Alert;
defineOptions({
name: 'TabsDemo',
components: { CollapseContainer, PageWrapper, [Input.name]: Input, [Alert.name]: Alert },
setup() {
const go = useGo();
const title = ref<string>('');
const { closeAll, closeLeft, closeRight, closeOther, closeCurrent, refreshPage, setTitle } =
useTabs();
const { createMessage } = useMessage();
function setTabTitle() {
if (title.value) {
setTitle(title.value);
} else {
createMessage.error('请输入要设置的Tab标题');
}
}
function toDetail(index: number) {
go(`/feat/tabs/detail/${index}`);
}
return {
closeAll,
closeLeft,
closeRight,
closeOther,
closeCurrent,
toDetail,
refreshPage,
setTabTitle,
title,
};
},
});
const go = useGo();
const title = ref('');
const { closeAll, closeLeft, closeRight, closeOther, closeCurrent, refreshPage, setTitle } =
useTabs();
const { createMessage } = useMessage();
function setTabTitle() {
if (title.value) {
setTitle(title.value);
} else {
createMessage.error('请输入要设置的Tab标题');
}
}
function toDetail(index: number) {
go(`/feat/tabs/detail/${index}`);
}
</script>