码农知识堂 - 1000bd
Python
PHP
JS/TS
JAVA
C/C++
C#
GO
Kotlin
Swift
pinia的基本使用和核心实现原理
前言
vuex缺点:ts兼容性不好、命名空间的缺陷、只能有一个store、mutation和action
pinia 优点:ts兼容性好 、不需要命名空间,可以创建多个store、mutation删掉了
pinia只具备以下几个属性,状态、计算属性、动作
pinia大小也会更小巧一些
我们先创建一个项目
下载依赖
安装pinia
main.js中使用pinia插件
在src下创建stores
stores我们先创建一个counter.js文件
用pinia里的defineStore方法创建一个store
actions里的this就指代store
同步异步方法都在action里处理
组件中使用
组件中可以在store里直接使用store中的状态、计算属性以及action里的方法,并且都是响应式的
创建store还可以传递一个setup函数
下面我们来实现它
在src下创建pinia文件夹,文件夹下创建createPinia.js、defineStore.js,这俩是pinia两个主要的api实现
再创建一个index.js把这俩api导出去
我们先来实现createPinia
用markRow标记,防止pinia被再次的做响应式处理,不让它变成响应式的
创建rootStore文件,用于存放一些名字
提供install方法
将pinia实例暴露到app上,所有组件都可以inject注入使用
保证vue2里也可以通过$pinia使用
将app保留一份在pinia上
所有store统一管理
创建一个scope独立空间
run方法的返回值就是回调函数fn的返回值
将state、scope和记录所有store放到实例上,还有保存着app的_a
我们再来实现defineStore.js
第一个参数可能是id也可能没有第一个参数,参数只有一个对象,name放在了对象里面,还有一种情况,第二个参数可能是一个对象也可能是一个setup
definedStore还需要提供useStore函数
返回useStore函数,内部注册一个Store
为了保证useStore在组件内部使用,那么我们需要通过判断currentInstance来保证useStore在组件内部使用ore
看一下pinia上有没有这个store,如果没有,说明是第一次使用这个store,那么我们就去创建一个调用createOptionsStore去创建一个store
createOptionsStore拿到用户传的state、getters、actions
我们要让外面的effectScope能够停止所有的store,也要让每个store能停止自己
处理setup函数
将state保存在pinia的state上对应的store的state中
将该store的state值返回出去
pinia里每一个store其实都是一个reactive
我们将每个store里的数据与这个store进行合并,扩展当前store的属性
将id也就是当前store的name名字与这个响应式store做一个映射保存在pinia的实例上,它是一个map映射
最后我们在useStore里把store进行返回
处理actions
actions里面有this问题,所以我们要处理actions的方法里的this
处理getters
用computed的原因是computed有缓存的性质
defineStore第二个参数除了对象的方式,还可以传一个函数的情况
判断第二个参数是不是一个setupStore,如果是函数,说明是一个setup语法
如果是setupStore创建setupStore,如果不是则创建我们之前实现的optionsStore
还是要先创建一个响应式的store,然后处理effectScope逻辑
然后处理actions的逻辑,以及最后合并的逻辑与之前创建optionsStore逻辑都一样,唯一不同的setup函数不用我们自己写了
最后建议
般不用高级语法的话,可以直接写成对象格式也就是optionsStore,更符合类似于vuex的语法
相关阅读:
浅学习泛型
【每日一题】旋变字符串
Centos7 入门
服务器RAS
Java枚举
剑指JUC原理-19.线程安全集合
华为云云耀云服务器L实例评测|重磅!华为云官方活动,教你一站式自动化部署
JavaScript基础: 异步
免费域名证书最新申请方式大全
Linux_/proc目录_查看处理器的信息/proc/cpuinfo
原文地址:https://blog.csdn.net/weixin_53312997/article/details/126284563
最新文章
攻防演习之三天拿下官网站群
数据安全治理学习——前期安全规划和安全管理体系建设
企业安全 | 企业内一次钓鱼演练准备过程
内网渗透测试 | Kerberos协议及其部分攻击手法
0day的产生 | 不懂代码的"代码审计"
安装scrcpy-client模块av模块异常,环境问题解决方案
leetcode hot100【LeetCode 279. 完全平方数】java实现
OpenWrt下安装Mosquitto
AnatoMask论文汇总
【AI日记】24.11.01 LangChain、openai api和github copilot
热门文章
十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
奉劝各位学弟学妹们,该打造你的技术影响力了!
五年了,我在 CSDN 的两个一百万。
Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
面试官都震惊,你这网络基础可以啊!
你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
心情不好的时候,用 Python 画棵樱花树送给自己吧
通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
13 万字 C 语言从入门到精通保姆级教程2021 年版
10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系
2656653265@qq.com
京ICP备2022015340号-1
正则表达式工具
cron表达式工具
密码生成工具
京公网安备 11010502049817号