上一篇 https://www.cnblogs.com/jyk/p/14706005.html 介绍了一个自己做的轻量级的状态管理,好多网友说,状态最重要的是跟踪功能,不能跟踪算啥状态管理? 因为vue3的状态都是 reactive 的形式,也就是 proxy,原本以为有自动跟踪的功能,但是后来发现,好像没有. 不管他有没有了,我们自己加上好了. 跟踪的两种方式 不记录调用者 只记录修改了哪个属性,和属性值,还有时间,其他的不管了.这个比较简单,直接套娃即可. 全套 不知道是谁(组件)触发的状态…
博客搬到了fresky.github.io - Dawei XU,请各位看官挪步.最新的一篇是:'用Roslynpad做一个轻量级的C#编辑器'.…
react状态管理方案有很多,其中最简单的最常用的是redux. redux实现 redux做状态管理,是利用reducer和action实现的state的更新. 如果想要用redux,需要几个步骤 actions 创建actions.js // actions.js export const SET_NAME = 'SET_NAME'; export const setName = (name) => { return { type: SET_NAME, name, } } reducer 创…
  最近连续看了几个GitHub上的开源项目,里面都用到了 Pinia 这个状态管理库,于是研究了一下,发现确实是个好东西!那么,Pinia 的特点: 轻量化 -- Pinia 体积约1KB,十分轻巧,加载运行都很快速,相对来说Vuex明显块头更大一些 Pinia 的 API 设计并非追求另辟蹊径,事实上它十分接近 Vuex 5的提案,并且对composition API非常友好(作者本身是Vue.js的核心成员,并且积极参与Vue Router以及Vuex的API设计) 模块化设计,支持创建数…
利用JavaScript(JS)实现一个可输入分钟的倒计时钟功能本文章为 Tz张无忌 原创文章,转载请注明来源,谢谢合作! 网络各种利用JavaScript做倒计时的Demo对新手很不友好,这里我亲手只做了一个案例,希望能帮助到读者们. 本Demo实现了输入数字可以开启倒计时功能,可以随时暂停.重置倒计时,并且对输入非数字类型其他字符进行了过滤以及提示! 整体思路: 1.利用JS获取一次当前时间,把用户在input输入框的内容,转化为我们所需要的数字 2.然后利用JavaScript的时间戳`g…
HTTP协议是无状态的,我们的客户端与服务器的每一次请求与响应,我们服务器都没有记忆能力将客户端与服务器的多次交互数据进行存储与管理共有两种技术实现: ●  基于客户端实现:Cookie,将状态保存在客户端中 ●  基于服务器实现:Session,将状态保存在服务器中…
仿照Rails实战:购物网站 教材:5-6 step5:计算总价,做出在nav上显示购物车内product的数量. 遇到的❌: 1. <% sum = 0 %> <% current_cart.cart_items each do |cart_item| %> <% if cart_item.product.price.present? %> <% sum = sum + cart_item.quantity * cart_item.product.price %…
Vuex 是不是有点繁琐? Vuex 是针对 Vue2 来设计的,因为 option API 本身有很多缺点,所以 Vuex 只好做各种补丁弥补这些缺点,于是变得比较"复杂". 现在 Vue3 推出了Composition API,功能更强大也弥补了之前的缺点,但是 Vuex 4.0 只是兼容了 Vue3,使用风格上似乎没啥变化. 于是乎怎么看怎么别扭,不是说 Vuex 不够强大,Vuex 的 state 也使用了 reactive ,而且也是用 provide/inject 实现注入…
一开始学习了一下 Vuex,感觉比较冗余,就自己做了一个轻量级的状态管理. 后来又学习了 Pinia,于是参考 Pinia 改进了一下自己的状态管理. 结合 Vuex 和 Pinia, 保留需要的功能,去掉不需要的功能,修改一下看着不习惯的使用方法,最后得到了一个满足自己需要的轻量级状态管理 -- nf - state. 设计思路 还是喜欢 MVC设计模式,状态可以看做 M,组件是V,可以用 controller 做调度,需要访问后端的话,可以做一个 services.这样整体结构比较清晰明了.…
Vuex 的遗憾 Vuex 是基于 Vue2 的 option API 设计的,因为 optionAPI 的一些先天问题,所以导致 Vuex 不得不用各种方式来补救,于是就出现了 getter.mutations.action.module.mapXXX 这些绕圈圈的使用方式.想要使用 Vuex 就必须先把这些额外的函数给弄明白. Vue3 发布之后,Vuex4 为了向下兼容只是支持了 Vue3 的写法,但是并没有发挥 composition API 的优势,依然采用原有的设计思路.这个有点浪费…