惠州市网站建设_网站建设公司_ASP.NET_seo优化
2025/12/25 1:30:51 网站建设 项目流程

好,这一段是Pinia 的 settings 全局配置仓库,再加上VueUse 的暗黑模式
你现在问的是「语法结构」,我就不扯业务细节,专门把每一层语法是干嘛的、为什么这样写讲清楚。


一、整体结构一眼看懂

import...import...constxxx=...constyyy=...constuseSettingsStore=defineStore('settings',{state:()=>({}),actions:{}})exportdefaultuseSettingsStore

👉这是 Pinia 的标准 Store 定义结构
可以拆成5 个语法层级

  1. import(依赖引入)
  2. 顶层普通变量(非响应式)
  3. defineStore定义 store
  4. state:响应式状态
  5. actions:方法(可改 state)

二、import 语法层

importdefaultSettingsfrom'@/settings'
  • 默认导入
  • defaultSettings是一个普通 JS 对象(不是响应式)
import{useDark,useToggle}from'@vueuse/core'
  • 命名导入
  • VueUse 提供的组合式函数
import{useDynamicTitle}from'@/utils/dynamicTitle'
  • 自定义工具函数
  • 修改document.title

三、普通变量(不属于 Pinia)

constisDark=useDark()consttoggleDark=useToggle(isDark)

语法重点

  • 写在 store 外面
  • 只会执行一次
  • 不会被 Pinia 重建
isDark// Ref<boolean>toggleDark()// 切换 isDark.value

👉 这是组合式 API + Pinia 混用的典型写法


四、解构默认配置(ES6 解构语法)

const{sideTheme,showSettings,navType,tagsView,tagsIcon,fixedHeader,sidebarLogo,dynamicTitle,footerVisible,footerContent}=defaultSettings

等价于:

constsideTheme=defaultSettings.sideThemeconstshowSettings=defaultSettings.showSettings...

作用:

  • 减少defaultSettings.xxx的重复书写
  • 提高可读性

五、localStorage 读取(短路语法)

conststorageSetting=JSON.parse(localStorage.getItem('layout-setting'))||''

语法点

  • JSON.parse(null)null
  • null || ''''

👉 所以storageSetting要么是对象,要么是空字符串

⚠️这也是为什么下面频繁用=== undefined判断


六、defineStore 语法结构(重点)

constuseSettingsStore=defineStore('settings',{state:()=>({}),actions:{}})

1️⃣'settings'

'settings'
  • store 的唯一 ID

  • 用于:

    • devtools
    • pinia 持久化
    • 跨模块引用

2️⃣state: () => ({})

state:()=>({title:'',theme:...,isDark:isDark.value})
语法规则
  • 必须是函数
  • 返回一个普通对象
  • Pinia 内部会自动转为reactive

等价概念:

conststate=reactive({title:''})

3️⃣ state 中的“或运算符 + 三元”

典型例子:

theme:storageSetting.theme||'#409EFF'
navType:storageSetting.navType===undefined?navType:storageSetting.navType
为什么不用||
false||true// 会变成 true(不符合预期)

所以用:

===undefined?默认值:本地值

👉这是一个非常成熟的 JS 防坑写法


七、actions 语法结构

1️⃣ 普通方法写法

actions:{changeSetting(data){...}}

等价于:

changeSetting:function(data){}

但这是ES6 简写


2️⃣this的含义(关键)

this[key]=value

在 Pinia 的actions中:

  • this👉store 实例
  • 等价于:
conststore=useSettingsStore()store[key]=value

3️⃣hasOwnProperty防御式写法

if(this.hasOwnProperty(key)){this[key]=value}

防止:

  • 写入不存在的字段
  • 拼写错误污染 store

4️⃣setTitle的语法重点

setTitle(title){this.title=titleuseDynamicTitle()}
  • 修改 state
  • 调用副作用函数
  • actions 可以有副作用(state 不行)

5️⃣ 切换暗黑模式

toggleTheme(){this.isDark=!this.isDarktoggleDark()}

语法重点:

  • this.isDark:Pinia 状态
  • toggleDark():VueUse 的 ref 操作
  • 两者同步,但不是同一个对象

八、export default

exportdefaultuseSettingsStore

使用方式:

constsettingsStore=useSettingsStore()settingsStore.toggleTheme()

九、一句话总结「语法结构」

这是「选项式 Pinia + 组合式 API」的混合写法

部分作用
import引入依赖
顶层 const非响应式工具
defineStore定义 store
state响应式数据
actions修改 state 的方法

如果你下一步想搞清楚:

  • 🔍为什么 isDark 不直接放 state 里
  • 🧠defineStore vs setup store 的区别
  • 🧹怎么改成 setup 风格

你直接说一句:
“讲 Pinia setup 写法”“这段怎么简化”就行。

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询