@/settings.js 属性名为 navType,但 store 内部状态键为 topNav。 destructuring 未做别名映射,导致 topNav 变量未定义, defineStore 初始化失败,actions.setTitle 不可用。
48 lines
2.0 KiB
JavaScript
Executable File
48 lines
2.0 KiB
JavaScript
Executable File
import defaultSettings from '@/settings'
|
|
import {useDynamicTitle} from '@/utils/dynamicTitle'
|
|
|
|
const {
|
|
sideTheme, showSettings, navType: topNav, tagsView, tagsViewPersist,
|
|
tagsIcon, tagsViewStyle, fixedHeader, sidebarLogo, dynamicTitle,
|
|
footerVisible, footerContent
|
|
} = defaultSettings
|
|
|
|
const storageSetting = JSON.parse(localStorage.getItem('layout-setting')) || ''
|
|
|
|
const useSettingsStore = defineStore(
|
|
'settings',
|
|
{
|
|
state: () => ({
|
|
title: '',
|
|
theme: storageSetting.theme || '#409EFF',
|
|
sideTheme: storageSetting.sideTheme || sideTheme,
|
|
showSettings: showSettings,
|
|
topNav: storageSetting.topNav === undefined ? topNav : storageSetting.topNav,
|
|
tagsView: storageSetting.tagsView === undefined ? tagsView : storageSetting.tagsView,
|
|
tagsViewPersist: storageSetting.tagsViewPersist === undefined ? tagsViewPersist : storageSetting.tagsViewPersist,
|
|
tagsIcon: storageSetting.tagsIcon === undefined ? tagsIcon : storageSetting.tagsIcon,
|
|
tagsViewStyle: storageSetting.tagsViewStyle === undefined ? tagsViewStyle : storageSetting.tagsViewStyle,
|
|
fixedHeader: storageSetting.fixedHeader === undefined ? fixedHeader : storageSetting.fixedHeader,
|
|
sidebarLogo: storageSetting.sidebarLogo === undefined ? sidebarLogo : storageSetting.sidebarLogo,
|
|
dynamicTitle: storageSetting.dynamicTitle === undefined ? dynamicTitle : storageSetting.dynamicTitle,
|
|
footerVisible: storageSetting.footerVisible === undefined ? footerVisible : storageSetting.footerVisible,
|
|
footerContent: storageSetting.footerContent === undefined ? footerContent : storageSetting.footerContent
|
|
}),
|
|
actions: {
|
|
// 修改布局设置
|
|
changeSetting(data) {
|
|
const { key, value } = data
|
|
if (this.hasOwnProperty(key)) {
|
|
this[key] = value
|
|
}
|
|
},
|
|
// 设置网页标题
|
|
setTitle(title) {
|
|
this.title = title
|
|
useDynamicTitle();
|
|
}
|
|
}
|
|
})
|
|
|
|
export default useSettingsStore
|