返回顶部
首页 > 资讯 > 前端开发 > JavaScript >前端的状态管理(上)
  • 519
分享到

前端的状态管理(上)

2024-04-02 19:04:59 519人浏览 八月长安
摘要

目录1、什么是前端状态管理?2、Vuex3、Bus 总线4、WEB storage前言: 提到状态管理大家可能马上就想到:Vuex、Redux、Flux、Mobx等等方案。其实不然

前言:

提到状态管理大家可能马上就想到:VuexReduxFluxMobx等等方案。其实不然,不论哪种方案只要内容一多起来似乎都是令人头疼的问题,也许你有适合自己的解决方案又或者简单的注释和区分模块,今天来聊一聊前端的状态管理,如果你有好的建议或问题欢迎在下方留言提出。

1、什么是前端状态管理?

举个例子:图书馆里所有人都可以随意进书库借书还书,如果人数不多,这种方式可以提高效率减少流程,一旦人数多起来就容易混乱,书的走向不明确,甚至丢失。所以需要一个图书管理员来专门记录借书的记录,也就是你要委托图书管理员给你借书及还书。

实际上,大多数状态管理方案都是如上思想,通过管理员(比如 Vuex)去规范书库里书本的借还(项目中需要存储的数据)

2、Vuex

在国内业务使用中 Vuex 的比例应该是最高的,Vuex 也是基于 Flux 思想的产品,Vuex 中的 state 是可以被修改的。原因和 Vue 的运行机制有关系,Vue 基于 ES5 中的 getter/setter 来实现视图和数据的双向绑定,因此 Vuex state 的变更可以通过 setter 通知到视图中对应的指令来实现视图更新。更改 Vuex store 中的状态的唯一方法是提交 mutation我们以图书馆来作为例子:


const state = {
  book: 0
}

const mutations = {
  borrow_book(state) {
    state.book ++
  }
}

//调用时
store.commit('borrow_book')

那还有action呢? 在 mutation 中混合异步调用会导致你的程序很难调试。你怎么知道是哪个先执行完呢? aciton 可以包含任意异步操作,用法跟上面基本类似,不再叙述。

其实我只是拿 Vuex 来浅入一下相关用法大家应该是都熟悉了,那 Vuex 解决了什么问题呢?

  • 管理多个组件共享状态。
  • 全局状态管理。
  • 状态变更跟踪。
  • 让状态管理形成一种规范,使代码结构更清晰。

实际上大部分程序员都比较懒(狗头保命),只是为了能多个组件共享状态,至于其他的都是事后了。最典型的就是加入购物车的数量,加入一个就通过 Vuex 记录保存最终的总数显示在下栏。

那问题来了,既然你的目的只是共享多个状态,那何不直接用 Bus 总线好了?

3、Bus 总线

Bus 总线实际上他是一个公共的 Vue 实例,专门处理 emit on 事件。

实际上 Bus 总线十分轻便,他并不存在 Dom 结构,他仅仅只是具有实例方法而已。


Vue.prototype.$Bus = new Vue()

然后,你可以通过 emit 来发送事件, on 来接收事件。


// 发送事件
this.$Bus.$emit('borrow_book', 1)

// 任意组件中接收
this.$Bus.$on('borrow_book', (book) => {
    console.log(`借了${book}本书`)
})

当然还有 off(移除)、once(监听一次)等操作感兴趣可以自行搜索引擎。

怎么样?上面对于满足共享一个状态是不是比 Vuex 要简单多了?实际上确实是简单多了,但这也代表他比较适合中小型项目。多于大型项目来说 Bus 只会让你追述更改源时一脸懵逼甚至你都不知道他在哪里改变了。

他的工作原理就是发布订阅者的思想,虽然非常优雅简单,但实际 Vue 并不提倡这种写法,并在3.0版本中移除了大部分相关api(emit、on等),其实不然,发布订阅模式我们可以自己手写一个去实现:


class Bus {
 constructor() {
  // 收集订阅信息,调度中心
  this.list = {};
 }

 // 订阅
 $on(name, fn) {
  this.list[name] = this.list[name] || [];
  this.list[name].push(fn);
 }

 // 发布
 $emit(name, data) {
  if (this.list[name]) {
                    this.list[name].forEach((fn) => {
                        fn(data);
                    });
                }
 }

 // 取消订阅
 $off(name) {
  if (this.list[name]) {
   delete this.list[name];
  }
 }
}
export default Bus;

简单吧?你只需要跟用 Vue Bus 一样去实例化然后用就可以了。什么?你想共享两三个甚至更少的状态(一个),那封装一个 Bus 是不是有点没必要了? 行吧,那你用 web storage 吧。

4、web storage

其实说到这,storage只是数据存储方式,跟状态管理其实没有太大关系,只是共享数据。但是既然都提到了那就顺带说一下(狗头)

web storage 有这三种:cookielocal storagesession storage

无论这三种的哪种都强烈建议不要将敏感信息放入其中,这里应该是加密或一些不那么重要的数据在里面。

先简单复习一下三者:

cookie 不必多说,大家发起请求时经常会携带cokie请求一些个人数据等,与我们要探讨的内容没有太大关系。

loaclStorage 可以存储理论上永久有效的数据,如果你要存储状态一般推荐是放在 sessionStoragelocalStorage 也有以下局限:

  • 浏览器的大小不统一,并且在 IE8 以上的 IE 版本才支持 localStorage 这个属性。
  • 目前所有的浏览器中都会把localStorage的值类型限定为string类型,这个在对我们日常比较常见的JSON对象类型需要一些转换。
  • localStorage在浏览器的隐私模式下面是不可读取的。
  • localStorage本质上是对字符串的读取,如果存储内容多的话会消耗内存空间,会导致页面变卡。
  • localStorage不能被爬虫抓取到。

localStorage sessionStorage 的唯一一点区别就是 localStorage 属于永久性存储,而 sessionStorage 属于当会话结束的时候,sessionStorage 中的键值对会被清空。

localStorage 本身只支持字符串形式存储,所以你存整数类型,拿出来的会是字符串类型。

sessionStorage localStorage 基本差不多,只是回话关闭时,数据就会清空。

总结:

不论哪种方案选择合适自己项目的方案才是最佳实践。没有最好的方案,只有合适自己的方案。

到此这篇关于前端的状态管理的文章就介绍到这了,更多相关前端的状态管理内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 前端的状态管理(上)

本文链接: https://lsjlt.com/news/154806.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 前端的状态管理(上)
    目录1、什么是前端状态管理?2、Vuex3、Bus 总线4、web storage前言: 提到状态管理大家可能马上就想到:Vuex、Redux、Flux、Mobx等等方案。其实不然...
    99+
    2024-04-02
  • 前端的状态管理(下)
    目录1、Redux1.1、Store(图书馆管理员)1.2、State(书本)1.3、Action(借书单)1.4、store.dispatch (提交借书单)1.5、Reducer...
    99+
    2024-04-02
  • vue前端开发辅助函数状态管理详解示例
    目录mapStatemapGettersmapMutationsmapActions示例小结mapState 当一个组件需要获取多个状态时候,将这些状态都声明为计算属性会有些重复和冗...
    99+
    2024-04-02
  • Angular 中的状态管理
    在Angular中,可以使用各种库和模式来管理应用程序的状态。以下是一些常见的Angular状态管理解决方案:1. 内置的RxJS:...
    99+
    2023-09-21
    Angular
  • Vue 状态管理策略:从单一状态树到分布式状态管理
    1. Vuex:单一状态树 Vuex 是 Vue 官方推荐的状态管理库,它采用单一状态树的模式,将所有状态集中管理在一个对象中。这使得状态更容易追踪和修改,提高了代码的可维护性。 // store.js import Vuex from...
    99+
    2024-02-24
    Vue 状态管理 Vuex Pinia 状态共享 状态隔离 状态持久化
  • Pinia.js状态管理器上手使用指南
    目录前言安装创建 StoreState定义State获取 state修改 stateGettersActions异步 actionaction 间相互调用数据持久化安装使用自定义 k...
    99+
    2024-04-02
  • 一文带你上手Vue新的状态管理Pinia
    目录Pinia 和 VuexPinia 核心特性Pinia 使用访问 stategetters更新和 actions支持 VueDevtools模拟调用接口跨模块修改数据Vuex 作...
    99+
    2023-05-15
    Vue状态管理Pinia使用 Vue状态管理Pinia Vue Pinia
  • react怎么管理状态
    这篇文章主要介绍“react怎么管理状态”,在日常操作中,相信很多人在react怎么管理状态问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react怎么管理状态”的疑惑有所帮...
    99+
    2024-04-02
  • Vue之Pinia状态管理
    目录一、认识Pinia1.1 认识Pinia1.2 为什么使用Pinia?二、 Store2.1 定义Store2.2 Option对象2.3 setup函数2.4 使用定义的Sto...
    99+
    2023-05-14
    Javascript Vue Pinia状态管理 Vue Pinia状态管理 Pinia状态管理
  • javascript Redux的状态管理详解
    所谓的状态管理,就是对应用程序中的数据进行管理。 理念:凡是数据流管理混乱的项目,几乎都上不了线。好的项目,必须有非常良好的数据流管理。 如何使用Redux?记住“3个3...
    99+
    2024-04-02
  • flutter 常见的状态管理器
    flutter 常见的状态管理器 前言一、Provider二、Bloc三、Redux四、GetX总结 前言 当我们构建复杂的移动应用时,有效的状态管理是至关重要的,因为应用的不同部分可...
    99+
    2023-09-03
    flutter javascript 前端
  • Angular需要状态管理吗
    这篇文章主要讲解了“Angular需要状态管理吗”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Angular需要状态管理吗”吧!在Angular中不是必须要...
    99+
    2024-04-02
  • 详解Vue3-pinia状态管理
    目录pinia是什么?官网安装命令使用pinia是什么? 这个是 vue3 新的状态管理工具,简单来说相当于之前 vuex,它去掉了 Mutations 但是也是支持 vue2 的,...
    99+
    2022-11-13
    Vue3-pinia状态管理 Vue3状态管理 Vue3 pinia状态管理 vue pinia是什么
  • vuex状态管理数据状态查询与更改的方法
    本篇内容介绍了“vuex状态管理数据状态查询与更改的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!状态管理数据状态查询与更改1.main...
    99+
    2023-06-30
  • 「Flink」Flink的状态管理与容错
    在Flink中的每个函数和运算符都是有状态的。在处理过程中可以用状态来存储数据,这样可以利用状态来构建复杂操作。为了让状态容错,Flink需要设置checkpoint状态。Flink程序是通过checkpoint来保证容错,通过c...
    99+
    2019-08-30
    「Flink」Flink的状态管理与容错
  • Vue3状态管理的使用详解
    目录背景 Provide / Inject 抽离共享状态提供数据 注入数据 小结 reactive 抽离共享状态使用共享状态 小结 结语 背景 随着Vue3的逐步应用,对状态管理的...
    99+
    2024-04-02
  • ReactMobx状态管理工具的使用
    目录Mobx与redux的区别使用安装observable&&autorunaction使用装饰器写法runInAction(异步)Mobx与redux的区别 mob...
    99+
    2023-02-06
    React Mobx React Mobx状态管理 React状态管理
  • 快速掌握Vue3.0中如何上手Vuex状态管理
    Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 也集成到 Vue...
    99+
    2024-04-02
  • vue状态管理实例分析
    这篇文章主要介绍“vue状态管理实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue状态管理实例分析”文章能帮助大家解决问题。场景:一个地图应用,有个侧边栏...
    99+
    2024-04-02
  • Android 状态管理之Lifecycle浅析
    目录原理概述构成模型源码1. addObserver(observer)2. sync()3. setCurrentState、moveToState监听其他1. Applicati...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作