news 2026/4/18 17:25:46

Vue-Pinia defineStore 语法结构

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue-Pinia defineStore 语法结构

好,这一段是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 写法”“这段怎么简化”就行。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 3:00:06

Promise 讲解

太好了&#xff0c;你这个问题问到 JS 异步的“命门”上了 &#x1f44d; 我不用 ruoyi、不用 axios、不用复杂概念&#xff0c;只用最最简单的例子&#xff0c;一步一步带你理解&#xff1a;什么是 return new Promise&#xff0c;以及为什么 getInfo() 要这样写一、先一句“人…

作者头像 李华
网站建设 2026/4/18 7:54:47

图解说明TouchGFX在STM32中的帧缓冲布局

深入理解TouchGFX在STM32中的帧缓冲布局&#xff1a;从原理到实战你有没有遇到过这样的问题——UI动画一动就卡顿&#xff0c;屏幕刷新时出现撕裂条纹&#xff0c;甚至刚画好的按钮瞬间“闪没”&#xff1f;如果你正在用STM32做图形界面开发&#xff0c;这些问题很可能不是代码…

作者头像 李华
网站建设 2026/4/18 5:34:39

2025年实蝇引诱剂无公害除虫推荐榜单:实蝇引诱剂无公害除虫

基于2025行业动态及市场研究报告&#xff0c;当前企业在需求实蝇引诱剂无公害除虫过程中&#xff0c;普遍面临信息杂乱、适配困难、质量参差等问题。信息杂乱使得企业难以快速找到真正适合自己的产品&#xff1b;适配困难导致所选产品可能无法在实际场景中发挥良好效果&#xf…

作者头像 李华
网站建设 2026/4/17 20:29:52

类似Open-AutoGLM的开源项目有哪些?这7个高星GitHub工具你不能错过

第一章&#xff1a;类似Open-AutoGLM的开源项目有哪些随着大语言模型自动化工具的发展&#xff0c;涌现出一批与 Open-AutoGLM 功能相似的开源项目&#xff0c;它们在自动代码生成、任务编排、自然语言到代码转换等方面提供了强大的支持。这些项目不仅推动了低代码/无代码平台的…

作者头像 李华
网站建设 2026/4/18 5:37:15

从零构建AutoGLM系统,你必须掌握的5个关键步骤

第一章&#xff1a;从零开始理解AutoGLM架构AutoGLM 是一种面向自动化自然语言处理任务的生成式语言模型架构&#xff0c;融合了图神经网络&#xff08;GNN&#xff09;与大规模预训练语言模型的优势&#xff0c;旨在实现对复杂语义结构的高效建模。其核心思想是将输入任务表示…

作者头像 李华
网站建设 2026/4/18 5:35:03

Altium Designer安装配置:小白指南从下载到激活

Altium Designer 安装配置实战指南&#xff1a;从零开始搭建专业PCB设计环境 为什么第一次安装 Altium Designer 总是失败&#xff1f; 你是不是也遇到过这种情况&#xff1a;兴致勃勃下载了 Altium Designer&#xff0c;结果双击启动时弹出“Failed to initialize DXP”&…

作者头像 李华